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About These Notes 


These notes discuss the technical aspect of the firmware and hardware of the AppleFax 
modem. It is intended to supply the information necessary to the developers to integrate the 
AppleFax modem into new environments. 
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Apple's main objective in releasing this information is to create a development environment 
for the AppleFax modem, and to ensure compatibility with third party software. The main 
sections of these notes consist of the hardware technical review, the firmware review, and 
information about the driver. Appendix B provides a hard copy of the object code 
necessary to address the driver. 


Most applications today interface with the AppleFax modem driver as if it were a standard 
printer resource. For applications such as these you are not required to make any code 
changes. Detailed information is supplied in these notes for those developers who wish to 
access the low level functions of the modem. For developers who wish this added 
functionality, the AppleFax library must be linked using the MPW linker. 


These preliminary notes do not constitute a manual and should not be considered complete 
in their present form. While every attempt has been made to verify the accuracy of the 
information presented, it is subject to change without notice. 


Supplemental Reference Documents 


In addition to these preliminary notes, it is suggested that the following publications be 
used as a source of reference: ee 


a Inside Macintosh, Volume 2 contains information on the Apple Print Manager. 
a AppleFax User's Guide contains basic information on the user application and 
technical appendices, including a complete list of modem commands. 


ao CCITT Specification T.30 “Procedures for Document Facsimile Transmisssion 
in the General Switched Telephone Network.” 


Terminology 

Alert Box A message displayed on the Macintosh screen to indicate 
action. 

AFInfoSize A firmware term indicating 64 bytes 

AppleFax station The station consists of the host Macintosh, the AppleFax 
modem, any serial device attached through the auxiliary port 
on the modem, and the phone equipment attached. 

bps Bits per second 

ByteTime A firmware term indicating 1 second 

Calls Commands sent between the host computer and the attached 
AppleFax modem 

CapSize A firmware term indicating 8 bytes 

Dialog Box A box of selectable parameters displayed on the Macintosh 
screen to allow the user to set desired parameters. 

Fax Station A station containing a standard facsimile machine rather than 
an AppleFax modem. 


Fax (Facsimile) Machine A Fax machine is capable of sending/receiving graphic 
transmission over the standard telephone lines from an 


9/29/87 AppleFax Modem Preliminary Notes 3 


FSK 

G2 Fax Machine 

G3 Fax Machine 

Host computer/processor 
IdentSize 

MaxLength 

MPW 

Packet 


PAL 

Result Codes 
ReturnTime 
SCC 


AppleFax modem and reproducing the image for hard copy 
only (it cannot store the image like the Macintosh). 


Frequency Shift Key 

Uses an older encoding format with a reverse bit order . 
Uses the Hoffman encoding format. 

Computer directly attached to the AppleFax modem. 

A firmware term indicating 20 bytes 

A firmware term indicating 1200 bytes 

Macintosh Programmers Workshop 


A group of formatted bytes used to transmit status and data 
between stations. 


Programmable Array Logic chip 

Specific error messages transmitted via packet format. 
A firmware term indicating 2 seconds 

Serial Channel Controller 


Software Checklist 


Before you install your AppleFax modem applications, verify the following files are on the 
3.5" disk included in your AppleFax modem seed package: 


co AppleFax modem driver 
c © AppleFax applications 
c FaxTest folder: contains sample applications demonstrating the use of the 


AppleFax library. 


- FaxTest.c: source code in C for the main part of the sample application. 
- FxCalls.c: source code in C to demonstrate how to make low level fax 


firmware calls. 


- FaxTestr: resource text file for the resources of the test application. 
- FaxTest.c.o: object code for FaxTest.c. 
FxCalls.c.o: object code for FxCalls.c. 
o Senos Fax Files folder: contains sample T4 and FaxFile formats. 


- Convert FaxFile: this is a fax file created from the received T4 file (see 
below) by using the library command FxConvertFile. 


- Receved T4: this file contains a T4 encoded image created by receiving the 
image in the AppleFax application. 
o FaxLib folder: contains the MPW created linkable AppleFax library. 
- FaxLib.o: AppleFax library. 
- FaxLibs: resource text file of resources required by the library routines. 
- FaxLib.Rsrc: actual resources required by the library. 
c FxIncludes folder: contains the include files required by the applications 
accessing the library. 
- Faxintf.p: PASCAL unit containing the structures and constants used by the 
AppleFax library. 
- FaxLibIntf.p: PASCAL interface file that defines the available library calls. 
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- Fax.h: C version of FaxIntf.p (you must use this file if you build the 
sample application FaxTest. 
o ACResDef folder: contains the include files needed to build the resources used 
by the library. | 
- FxTypes.r: resource include file required to 'REZ' FaxLib.r. 


AppleFax Functional Overview 


This portion of the developer notes elaborates on the technical discussion given in 
Appendix F of the AppleF'ax Modem User's Guide. Figure | provides a more detailed 
functional block diagram. Additional technical information is also provided. 


Hardware Configuration 


The AppleFax electronics are arranged on.a 5-inch by 8-inch printed wiring board assembly 
(here after referred to as the digital module) with the fax modem logic installed piggyback 
onto the board at connector J5. The digital module contains the microprocessor, RAM and 
ROM chips, three programmable array logic (PAL) chips, Serial Channel Control (SCC) 
chip, and miscellaneous supporting logic. Also included in the hardware is an external 
power supply used to provide +12V and +5V power. A -5V regulator installed on the 
digital module board generates the -5 V power. 


The digital module contains five on-board connectors labeled J1, J2, J3, and JSA/B. These 
connectors and their function are listed below: 


Connector Function 


J1 Interface to/from the host 

J2 Interface to/from pass-through port 

J3 RJ11 type connector to/from phone lines 

J5 Fax modem circuitry to/from digital module 


Functional Description — 


The AppleFax modem operates in one of two modes: FAX mode and the PASS- 
THROUGH mode. In FAX mode, the modem functions as a standard facsimile (fax) 
machine either in normal fax operations or in a high-speed data communications mode. In 
the PASS-THROUGH mode, the AppleFax modem is used simply to pass information 
between the attached host computer (Macintosh) and many kinds of serial devices 
connected to the auxiliary port of the modem. The following paragraphs discuss each of 
these modes in reference to the functional block diagram given in Figure |. 


Operating in the AppleFax mode, your station can act either as the sending station, to 
initiate the facsimile transmission, or as the receiving station. As a sending station, the host 
computer initiates the facsimile operation by sending a series of commands (in firmware 
these commands are referred to as Calls) through the interface (J1) to the attached AppleFax 
modem. The commands are received by the resident microprocessor in the AppleFax 
modem, which in turn initiates the facsimile operation. The operation is begun by dialing 
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the phone number (given by the host computer) of the destination fax. Once the destination 
fax acknowledges (OK), data transmission begins. All communications between the host 
processor and the AppleFax modem are serial using RS-422 serial communication 
protocol. Information is received from the host processor on the RXD- and RXD+ lines 
which represents both polarities of the receive line. These signals are filtered and fed to the 
differennal receiver, which drives the RXDB line to the Serial Channel Controller (SCC) 
and to the address decode PAL. 


When the AppleFax modem is acting as the receiving station, its ring detection logic detects 
the incoming call and signals the PAL, which informs the microprocessor. The 
microprocessor sends the OFHK (offhook) signal to the line selector relay, which selects 
the phone line for transmission by closing two switches (see Figure 1). The phone line 
driver and receiver circuitry is used both to supply current to the phone line through the 
coupling of the audio transformer, and to act as a receiver to transfer signals from the 
phone line to the fax modem logic. The audio transformer serves as an isolator for the 
main electronics from the phone line to the driver/receiver. 


Once the modem receives the information, the data pump logic takes over. The data pump 
logic is a R96 compatible chip set that is physically mounted in piggyback fashion to the 
main digital module. This logic interfaces to the microprocessor through the data bus and 
through a synchronous bit-oriented channel to the SCC. Ultimately, the data pump is 
responsible for transmitting the serial data bits using the TXA line. The TXA line is sent 
through the driver amplifier and passed onto the audio coupler to the phone lines. 
Similarly, it receives serial bits transmitted from other stations through the RXA line. The 
data pump then sends the serial data bits to the SCC for conversion into parallel data via the 
synchronous modem data channel. 


The data pump logic contains three tone detectors and a tone generator used for tone 
signalling and detection. In the 300 bps FSK receive configuration, the presence of tones 
at preset frequencies is indicated by the pattern of sequenual bits in the interface memory 
modem. This memory is read by the microprocessor. Refer to Appendix G in the 
AppleFax Modem User's Guide for a list of the tonal signal frequencies, transmitter carrier 
frequencies, and the signalling data rates. 


The data pump provides equalization functions that can be used to improve performance 
during operation over poor telephone lines. One function is the use of cable equalizers to 
optimize performance over different lengths of non-loaded cables. Also, line amplitude 
equalizer are used in the transmit and receive paths. And lastly, an automanc adaptive 
equalizer is used in the receiver circuit for V.27ter and V.29 configuration. 
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Figure 1: AppleFax Modem Functional Block Diagram 
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Firmware Technical Overview 


This section of the developer notes contains a description of the firmware that resides in the 
ROM of the AppleFax modem. Refer to Appendix C of the AppleFax Modem User's 
Guide for a list of the modem commands. 


The first function of the AppleFax modem firmware is to perform power-up self tests. 
Upon power-up of the modem, the firmware examines the contents of the first three bytes 
of the test page addresses ($4000 through $77FF). If these locations contain a jump 
instruction to $4003, the firmware will branch to address $4000. At this point, the test 
fixture code performs a comprehensive test of the modem. 


In the next phase of the power-up sequence, the firmware performs self tests on the 
modems main components listed below to determine their functionality. 


Component Functional Test 


ROM Firmware calculates the ROM checksum and compares it 
with its correct value. 

RAM Firmware perfotms several simple tests to ensure RAM 
functionality. . 

SCC The SCC is minimally tested by the firmware. 


Data Pump Minimal functional tests performed by the firmware. 


If any of these self-tests fail, the indicator lights on the front of the AppleFax modem will 
alternately blink (four cycles per second). Upon successful completion of the self-tests, the 
modem enters the AT command mode. 


AppleFax Operating Modes 


The AppleFax modem operates in one of four firmware modes: AT Command mode, Data 
mode, Pass-Through mode, and Fax Command mode. Upon power-up, the modem will 
always enter the AT Command mode. The remaining modes are entered from the AT 
Command mode only, and exit back to that mode. Figure 2 shows the various commands 
used to enter and exit specific modes. Typically, the Pass-Through mode is entered using 
the front panel switch; however it can also be entered using the AT command, AT>. 
Exiting from the Pass-Through niode can be done using the front panel switch or the exit 
Character. Each of the four modes are discussed further in the following paragraphs. The 
panel switch 1s operational only between the AT command mode and Pass-Through mode. 


AT Command Mode 


The AppleFax modem accepts commands sent form the host computer, or another 
AppleFax station, once it receives a specific string of characters. When one of these 
specific strings of characters is transmitted (either AT, at, A/, or a/ ), the AppleFax 
modem enters the AT Command mode and interprets all subsequent characters as 
commands from the AT command set. A complete list of these commands is contained in 
Appendix C of the AppleFax Modem User's Guide. The AppleFax modem will continue 
to interpret the characters as commands until an error occurs (such as over 64 characters 
transmitted) or until a RETURN is transmitted. The AppleFax station will return responses 
to the AT commands if you have not turned the Quiet command on. 
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Figure 2: AppleFax Modem Firmware Operational Modes 


When you first power-on the AppleFax modem it will be in the AT command mode and 
ready to accept any AT command from the AppleFax host computer. To recognize the 
transmission as commands, the AppleFax modem must first receive either an AT or at 
sequence. All subsequent transmissions will then be interpreted as AT commands. If the 
first command received is either the A/ or a/ String, the modem will interpret it as if it were 
the AT or at command string. 


At the first occurrence of an AT or at sequence, the AppleFax modem will automatically 
determine the baud rate. This baud rate will be used until the modem is turned off, or until 
any reset command is issued. 


If connection is made with another AppleFax modem using either the ATA command or 


the ATD command, your modem will enter the data mode (also referred to as the ‘online’ 
mode). To exit the data mode and return to the AT command mode, you must execute the 


AppleFax until you send an ATH command to hang up the phone. You can enter data 
mode any time prior to the ATH command by typing the ATO command. 
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Other modems that use the AT command set differ from the AppleFax modem in that the 
escape sequence consists of [pause]+++[pause]. Upon receiving this escape sequence, 
the modem enter the command mode and returns an OK response. To remain compatible 
with these other modems, the AppleFax modem recognizes the [pause]+++[pause] 
sequence while in the data mode, and will return the OK response. However, the modem 
will not enter the command mode unless it detects an AT or at as the very next character 
sequence. 


Data mode 


The AppleFax modem operates in the data mode for data transmission and reception 
between fax modems. Data mode is entered only from the AT Command mode using the 
ATD, ATA, and ATO commands. To exit the data mode, use the escape sequence. 


Fax Command mode 


The Fax command mode is entered only from the AT Command mode using the AT: 
command. To exit this mode, use the fax command Reset or power down the modem. 
While in the Fax Command mode, communication with another AppleFax station, and 
sending and receiving to a fax machine are performed. Other miscellaneous operations also 
take place from this mode, such as viewing and setting register values, obtaining status, 
and getting the results of the previous command. Figure 2 shows the operations performed 
from the Fax Command mode and lists the commands associated with each operation. A 
description of these commands follows the mode discussion. 


Pass-Through mode 


The AppleFax modem operates in the Pass-Through mode when communication is berween 
the host computer and the device attached to the auxiliary port of the AppleFax modem. 
Data being transmitted from the host to the attached device passes through the modem with 
no data manipulation by the modem. The modem is used Strictly as a transmission path. 


The data lines of the two serial ports are connected by hardware circuits to allow data, at 
any rate, to be passed directly through the modem. The control lines, however, are passed 
through using software control. This causes a minute delay from the input on one port to 
the output on the other. This delay is less than 65 microseconds and should not affect the 
operation of most devices, however, some specialized interfaces might be affected. The 
signals that are delayed are listed below: 


Host Port | 

GPi (7) <-- GPi (7) 
HSKO (1) <-- HSKI (2) 
HSKI (2) --> HSKO (1) 


Entry into this mode can be done from the AT command mode using the AT> command or 
by using the modem's front panel switch. The front panel switch is only operational from 
the AT command mode and not from the Data mode or Fax mode. Prior to using the AT> 
command, register S15 must be set to enable the command character (>). 
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ayes. 


To enable the Pass-Through Mode command character (>), set register S15 to a value 
greater than 256. Setting this register to a value less than 256 will disable the command. 
Use the following format to specify the exit character: 

ATSIS5 = VAL 


where VAL is 256 + [exit character]. The exit character in this equation is the ASCII value 
of the character you have chosen. Register S15 has a default value of 0, which disables the 
Pass-Through mode command. It can be set with any value between 0 and 511. 


Resets 


The AppleFax modem can be reset using one of three methods depending on the mode you 
are operating in. The normal way to perform a reset is to use the Reset command 
(command number 14). This command is used by the host computer and overrides all 
other commands. If you are in the AT Command mode, you can issue the ATZ command. 
The third way to reset the modem is used in emergencies from the Fax Command mode by 
sending a string of 2-bytes containing the value '2121' (ASCII characters !f ) until they 
begin to echo back. Once you see the exclamation mark (!) being echoed back, it means the 
modem has been reset and you are in AT command mode. 


Operation of the AppleFax. 


As previously mentioned, upon initial power-up, the AppleFax modem enters the AT 
command mode. To communicate between the modem and the host computer using 
"packets” you must be in the Fax Command mode. The packets used during the 
communication are an organized method of packaging the data, commands, and status 
information for transfer. The protocol setup between the host computer and the modem 
begins with the host computer sending packets containing commands and data to the 
modem, and the modem returning packets containing status, results, and data. Each packet 
also contains checksum information to allow the detection of any transmission errors. 


If your host computer is a macintosh, use the AppleFax library to handle the packet 
protocol for you (see ““AppleFax Library” paragraph later in these notes). 


The packet protocol between the modem and a host computer consists of the three types of 
packets listed below: 


co Command packet: from host to modem 
o Return packet: from modem to host (automatically sent) 
a Result packet: from modem to host (only sent when asked for) 


The host computer sends a command packet to the modem, which begins to execute the 
command. Some of the commands execute immediately and send the return packet upon 
completion. Other commands, however, take a variable length of time to execute, and 
therefore, do not send a return packet. In these cases, the host computer must monitor the 
progress of the command during execution. The progress of the command is monitored by 
sending a Status request to the modem. A Status request is a special command that is 
serviced even while another command is executing. The Status request returns information 
about the modem which includes the state of the currently executing command. The host 
computer can determine from the returned information that the command has completed its 
execution. To determine the results of the command, the host computer sends a GetResult 
command to the modem. In response, the modem returns a result packet to the host . 


9/29/87 AppleFax Modem Preliminary Notes 1 


A 2-byte confirmation format is used between the host computer and the modem to confirm 
transmission. These confirmation bytes contain a value of either '0101' to indicate 
transmission received; or a value of '0202' indicating the transmission sent was erroneous, 
retransmit. An exception to this is the TransmitLine command. The AppleFax modem 
does not respond with confirmation bytes when this command is sent from the host . 


In summary, there are 3 types of packets: command packets, which cause the modem to 
begin executing a command; return packets, which some commands return immediately 
upon completion; and result packets, which the modem sends in response to a GetResult 
command. A fourth type of packet, the control packet, is used that does not conform to 
the basic packet format. 


Now that you know the basic communication protocol, let's discuss the following fax 
operations: 


Calling a fax machine or another AppleFax station 

Receiving a call from a fax machine or another AppleFax station 
Sending fax files to a fax machine 

Receiving fax files from a fax machine 

Transferring data between AppleFax stations 

Closing the connection — 


000 0 0 0 


The structure and contents of the command, return, and result packets for the commands 
mentioned in the following operations are given later in this document under Fax modem 
command formats’. 


Calling a Fax Machine or Another AppleFax Modem 


To call another AppleFax modem or a fax machine, the modem must be in the Fax 
command mode. Entry to the Fax Command mode is obtained only from the AT 
Command mode using the AT: command. To establish communication, the host computer 
issues the FaxDial command using the command packet format. The FaxDial command 
packet contains the following information: 


The phone number to dial 

The host computer's station identification 

Fax information (vertical resolution, transmission parameters) 
Mode: standard, or AppleFax 

Extended AppleFax identification, if applicable 


The Mode field specifies how the fax modem should identify itself to the target device. 
Standard tells the AppleFax modem to act just like a standard fax machine. AppleFax 
indicates the modem is to identify itself as an AppleFax modem and enter packet transfer 
mode if the other device is also an AppleFax modem. 


Issuing the FaxDial command causes the modem to dial the phone number indicated and 
wait for the phone to be answered. If the phone is answered by a fax machine or an 
AppleFax modem, the modem receives its station identification and determine its 
capabilines. The host computer issues Status requests until it is determined that the 
command has completed execution. 


Ooo OC U0 
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Once execution complete is determined, the host computer issues the GetResult command 
to the modem. The modem then returns the information received from the remote device in 
the form of a result packet. This packet contains the following information: 


ca Was the call answered by a compatible device? 

The answering device's station identification 

Fax information (vertical resolution, transmission parameters) 
Mode: standard, or AppleFax 

Extended AppleFax identification, if applicable 


Oo og oO O 


If the Mode is ‘standard’, the host computer must execute a FaxTransmit command 
following the completion of the FaxDial command. If, however, the mode is ‘AppleFax’, 
the host computer must begin to execute packet transfer commands, described below. 


Receiving a Call from a Fax Machine or Another AppleFax Station 


Like the transmission operation, the AppleFax modem must be in Fax Command mode in 
order to be able to receive a call from another station. The host computer issues a 
GetRegister command to examine the number of rings that have occurred since the Fax 
Command mode was entered, or since the SetRegister command was issued to reset the 
register. The number of rings is contained in modem register 1. Once the host computer 
determines that enough rings have occurred, it issues the FaxAnswer command. This 
command functions similar to the FaxDial command except that it connects immediately to 
the phone line rather than dialing a number first. The modem passes on the information 
received from the sending station in a result packet when the host computer issues a 
GetResult command. | 


If the Mode returned is set to standard, the host computer must immediately execute a 
FaxReceive command. If the mode is AppleFax, the controller begins to execute packet 
transfer commands, described below. 


Sending an Image to a Fax Machine: 


Once connection to the target fax is established and the FaxTransmit command 1s issued, 
the host computer executes a TransmitLine command for each line of graphics data from the 
image. The controller must prepare each line of raw graphics data before sending it 
according to the current transmission mode. If the target is a group 3 fax machine, the data 
must be converted to Huffman encoded run length form as specified by CCITT 
specification T.4. If the target is a group 2 fax machine, the data is non-encoded and 
converted to lines of exactly 1728 bits (216 bytes). After the last line of data for a page has 
been sent, a TransmitEnd command must be executed. TransmitEnd returns a flag to 
indicate whether or not the quality of the received image was acceptable. If the quality was 
unacceptable, the host computer may retransmit the image, perhaps forcing the modem to 
use a lower data rate. For multiple page documents, the host computer issues another 
FaxTransmit command and repeats the process. 


To better illustrate the method by which fax data is transmitted, some sample procedures 


are provided on the 3.5 disk supplied with your seed package. These samples are 
contained in the Fax File folder on the disk. 
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Receiving an Image From a Fax Machine: 


When connection is made with a sending device, the host computer issues a FaxReceive 
command to the modem to determine if a page is available to be received. If a page is 
available, the controller immediately begins executing ReceiveBuffer commands, which tell 
the modem to return blocks of compressed graphics data to the host computer. 
ReceiveBuffer commands must be executed often enough to keep up with the average rate 
of data coming from the transmitting station. If the sending fax is a group 3 machine, the 
data must be converted from Huffman encoded run length form as specified by CCITT 
specification T.4. If the sending fax is a group 2 machine, the data is non-encoded and 
converted to lines of exactly 1728 bits (216 bytes). 


ReceiveBuffer sets a flag in the return packet when all of the image data for a page has been 
received. When the host computer detects this flag, it executes a ReceiveEnd command. 
This command tells the modem whether the quality of the received image was acceptable. 

It then issues another ReceiveBuffer command to determine if more pages are available, 
and if so, it repeats the receive process. 


To better illustrate the method by which fax data is captured during reception, stored in a 
temporary file, and then converted by the library, some sample procedures are provided in 
Appendix C of these Preliminary Notes. * 


Transferring Data Between AppleFax Stations 


When communication is between two AppleFax stanons, packet transfer commands are 
used to exchange data between the two modems. These commands are the TransmitPacket 
and ReceivePacket commands. They allow the host computer to send data to and receive 
data from the other AppleFax station in packet format. ( 


Closing a Connection 


When communication between the host computer and the target station is complete, the 
Disconnect command is issued by the controller to terminate the transmission. 


AppleFax Modem Command Formats 


As shown in Figure 2, communication and transmission operations are accomplished from 
the Fax Command mode. Each of the operations performed under the Fax Command mode 
require certain commands with specific packet formats. Before we get into the command 
formats, it is helpful to understand the definitions of certain words and phases used 
throughout the discussion: 


Term Meaning 
ByteTime 1 second. 
Return Time 2 seconds. 
MaxLength 1800 bytes. 
CapSize 8 bytes. 
IdentSize 20 bytes. 
AFInfoSize 64 bytes. 
PNumSize 64 bytes. 
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Definition of Packet Formats 
To summarize packets, it is important to remember there are three types of packets; 
command packets, return packets, and result packets. All three packets have the same 


basic format, shown in Figure 3. Each field of the format is discussed following the 
figure. 7 


Type Length Checksum 1 Data Checksum 2 
1 Byte 2 Bytes | Byte n Bytes 2 Bytes 


Figure 3: Packet Format 


Type This 1 byte field contains a value indicating the type of packet being 
transmitted: 
Command packet = command number + $80 (128) 
Result packet = command number + $CO (192) 
Return packet = command number + $40 (64) 

Length The 2 byte Length field contains a value indicating the number of the 
actual data bytes. This value must not exceed the MaxLength of 1800 
bytes. 


Checksum1 This 1 byte field contains a value that is the sum of the first three bytes 
. of the packet. It is provided to verify that the length field has been 
correctly transmitted before an attempt is made to read the rest of the 
packet. 


Data Data is a variable field that contains the actual data being transmitted. 
The maximum number of bytes in this field is 1800 bytes (MaxLength). 


Checksum2 This 2 byte field contains the sum of the data bytes in the data field. If 
there is no data in the data field, this value is zero. 


Commands are sent between the fax modem and the host processor using the format 
shown in Figure 3. Each of the commands is assigned a command number, as listed on 
the following page: 


9/29/87 AppleFax Modem Preliminary Notes 15 


Col 


0 Status 
l FaxDial 
2 FaxAnswer 
3 7 Fax Transmit 
4 TransmitLine 
5 TransmitEnd 
6 FaxReceive 
7 ReceiveBuffer 
8 ReceiveEnd 
9 TransmitPacket 
10 ReceivePacket 
11 Disconnect 
12 SetRegister 
13 GetRegister 
14 Reset 
15 Not Used 
16 Version 
17 GetResult 
18 PickUp 
19 HangUp 


Result Codes 


The result field of the basic packet protocol format is used in all result packets and in the 
return packet of the Status command. This 1 byte field contains a code indicating the 
current status. These result codes, their meaning, the hex value, and the decimal value are 
listed below: 


Hex Decimal 
Result Code Value _Value’ Meaning 
Executing $01 (1) Command still executing. 
NoErr $00 (0) Command execution successful. 
InvalidErr SEC (-20) Command invalid and cannot be executed. 
TOutErr $FF ‘ (-]) A time out occurred with the remote device. 
CommeErr SFE (-2) Communication error occurred with remote 

device. 

IncompExr SFD (-3) Remote device is incompatible. 
NolmageErr $F6 (-10) No image is available to be received. 
SystemErr SF5 (-11) Modem has had a fatal system error. 
TooLongErr SF4 (-12) Modem received packet that was too long. 
OverFlowErr SF3 (-13) Some image data lost due to buffer overflow. 
LongStrErr SE2 (-30) A String in the command is too long. 


All of the commands are transmitted and received using the packet format shown in Figure 
3. The data field of that format differs for each command. The following pages contain 
descriptions of the commands along with a description of the contents of the data field for 
the three types of packets. 
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Status Command (command number 0) 


The Status command is a specialized command that can be serviced by the modem while 
another command is executing. The command is sent in the protocol format shown in 
Figure 3. The contents of the data field of that format is given below for each of the 
packet types: 


Command Packet Data 


Empty (0 bytes) 


Return Packet Data 
Result Command Status 
1 Byte 1 Byte 1 Byte 


Result If the command indicated in the command byte has not completed 
execution, the result byte contains the result code Executing, $01 (1). 
However, if the command has completed execution, the result byte 
contains the result value of the last command. Issue the GetResult 
command to obtain the command's complete results. 


Command The command byte contains the command number of the currently 
executing command, or the last command executed. If no command 
has been executed, $FF (-1) is returned. 


Status The status byte is used to indicate if data transmission is complete or if 
there is still more data to be transmitted. When the Transmit Busy bit, 
bit O of the status byte, is set to 1, it indicates there is still data to be 
transmitted from the AppleFax modem's internal bufffers to the remote 
device. When set to 0, it indicates that data transmission is complete. 
Bits 7 - 1 are undefined. 


Result Packet Data 


The Status command does not affect the result buffer. 
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FaxDial Command (command number 1) 


The FaxDial command is used by the host computer to tell the modem to dial the target 
station. This command contains the following information in its data field: 


Command Packet Data 


| PhoneNum | ident - Capabilities [ Mode _ 
| mn Bytes n Bytes n Bytes | | Byte 


: AFIRec | 
n Bytes 


Phone Number _ This is a variable length field containing the phone number of the target 
station. Its format consists of a length byte followed by a string 
containing the phone number and any special symbols defined under 
the ATD modem command in Appendix C of the AppleFax Modem 
User's Guide. The length of this field must not exceed the 
PNumberSize (64 bytes). 


Ident This is a variable length field containing the host computer 
identification string. The format of this field begins with a length byte 
followed by a string composed of spaces and digits. Its length must 
not exceed the IdentSize (20 bytes). 


Capabilities This is a variable length field that contains a string of data preceded by 
a length byte. The string of data describes the host computer and has 
the format of T.30's DCS packet. The length of this field must not 
exceed CapSize (8 bytes). See Appendix A for a description of the 
contents of the data string bytes. 


Mode This is a 1 byte field that specifies either Standard or AppleFax mode 
for the host computer. The values are: 
Standard = 0 
AppleFax = 2 

AFTRec This is a variable length field that specifies the host computer's 


AppleFax identification to the remote device. It contains a string 
preceded by a length byte, and must not exceed AFInfoSize (64 bytes). 
This field is user defined for such things as version numbers. 


Return Packet Data 


FaxDial is not executed immediately and therefore does not have a return packet. The host 
computer must monitor this command using the Status command in order to know when 
to get the result data using the GetResult Data command 
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Result Packet Data 


Result ident ResultCap Mode AFiRec | 
1 Byte nN Bytes n Bytes 1 Byte n Bytes 


Result 


Ident 


ResultCap 


Mede 


AFiRec 
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This is a 1 byte field containing one of the following result codes: 
Code. Meaning_ 

NoErr Command successfully executed. 

InvalidErr | Command is invalid and cannot be executed. 

TOutErr A time out occurred. 

CommeErr Communication error occurred with the remote device. 


IncompErr The remote device is incompanble. 
SystemErr The modem has had a fatal system error. 


This is a variable length field containing the target device identification 
string. The format of this field begins with a length byte followed by a 
string composed of spaces and digits. Its length must not exceed the 
IdentSize (20 bytes). | 


This is a variable length field that contains a string of data preceded by 
a length byte. This field contains the result obtained when the 
AppleFax modem compares the capabilities designated in the command 
packet with the capabilities of the target device and selects the 
appropriate mode. It has the format of T.30's DCS packet. See 
Appendix A for a description of the contents of the data string bytes. 


This is a 1 byte field that returns the mode selected by the modem when 
it compared the capabilities of the two devices. AppleFax mode is 
returned only when both devices are AppleFax modems. 


This is a variable length field that specifies the host computer's 
AppleFax identification to the remote device. It contains a string 
preceded by a length byte, and must not exceed AFInfoSize (64 bytes). 
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FaxAnswer Command (command number 2) 


This command is issued to the modem to cause it to answer the phone and establish a 
connection with the transmitting stanon. The command parameters and its return values 
are the same as-the FaxDial command. 


Command Packet Data 


ident Capabilities | Mode AFiRec sid 
n Bytes mn Bytes 1 Byte n Bytes 


Ident This is a variable length field containing the host computer 
identification string. The format of this field begins with a length byte 
followed by a string composed of spaces and digits. Its length must 
not exceed the IdentSize (20 bytes). 


Capabilities This is a variable length field that contains a string of data preceded by 
a length byte. The string of data describes the host computer and had 
the format of T.30's DCS packet. The length of this field must not 
exceed CapSize (8 bytes). See Appendix A for a description of the 
contents of the data string bytes. 


Mode This is a 1 byte field that specifies either Standard or AppleFax mode 
for the host computer. The values are: 
Standard = 0 
AppleFax = 2 

AFTRec This is a variable length field that specifies the host computer's 


AppileFax identification to the remote device. It contains a string 
preceded by a length byte, and must not exceed AFInfoSize (64 bytes). 
This field is user defined for such things as version numbers. 


Return Packet Data 
FaxAnswer does not have a return packet. 


Result Packet Data 


| Resuit | Ident ResuliCap 
| 1 Byte j; 1 Bytes n Bytes 


Result This is a 1 byte field containing one of the following result codes: 
Code Meaning. 
NoErr Command successfully executed. 
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Ident 


ResultCap 


Mode 


AFIRec 
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| InvalidErr | Command is invalid and cannot be executed. 


TOutErr A time out occurred. 

CommErr Communication error occurred with the remote device. 
IncompErr The remote device is incompatible. 

SystemErr The modem has had a fatal system error. 


This is a variable length field containing the target device identification 
string. The format of this field begins with a length byte followed by a 
string composed of spaces and digits. Its length must not exceed the 
IdentSize (20 bytes). 


This is a variable length field that contains a string of data preceded by 
a length byte. This field contains the result obtained when the 
AppleFax modem compares the capabilities designated in the command 
packet with the capabilities of the target device and selects the 
appropriate mode. It has the format of T.30's DCS packet. See 
Appendix A for a description of the contents of the data string bytes. 


This is a 1 byte field that returns the mode selected by the modem when 
it compared the capabilities of the two devices. AppleFax mode is 
returned only when both devices are AppleFax modems. 


This is a variable length field that specifies the host computer's 
AppleFax identification to the remote device. It contains a string 
preceded by a length byte, and must not exceed AFInfoSize (64 bytes). 
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FaxTransmit Command (command number 3) 


The FaxTransmit command is issued by the host computer within 35 seconds of the 
FaxDial command if the mode is set to Standard. This command prepares the AppleFax 
modem to transmit a page of graphics data to the target device. 


Command Packet Data 
None (0 bytes) 


Return Packet Data 
Fax Transmit does not have a return packet. 


Result Packet Data 


The data field in the result packet contains 1 byte of result information. This 1-byte field 
contains one of the following result codes: 


ode Meaning. 
NoErr Command successfully executed. 
InvaliidErr | Command is invalid and cannot be executed. 
TOutErr A time out occurred. 
CommeEtrr Communication error occurred with the remote device. 
SystemErr The modem has had a fatal system error. 
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TransmitLine Command (command number 4) 


After the issuance of a FaxTransmit command, the host computer issues a TransmitLine 
command for each line of raw graphics data to be sent. This command sends a line of data 
from the host computer to the AppleFax modem for transmission to the target station. The 
TransmitLine command is the only command that does not send confirmation bytes back 
to the host. 


Command Packet Data 


Length Data 
2 Bytes n Bytes 
Length This is a 2 byte field containing the number of bytes in the following 
variable length data field. : 
Data This is a variable length data field containing the raw graphics data to 
be transmitted. | 


Return Packet Data 
TransmitLine does not have a return packet. 


Result Packet Data | 
The data field in the result packet contains 1 byte of result information. The possible result 


data are: 
Code Meaning. 
NoErr Command successfully executed. 


InvalidErr | Command is invalid and cannot be executed. 

TOutErr _A time out occurred. 

CommErr ~~ Communication error occurred with the remote device. 
SystemErr The modem has had a fatal system error. 
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TransmitEnd Command (command number 5) 


This command is issued by the host computer to terminate the transmission of a graphic 
image. | 


Command Packet Data 


This data field consists of 1 byte of data indicating the last page was transmitted. If the 
value of this field is 1, the last page of data was transmitted. If this value is 0, it indicates 
more transmissions are to come. 


Return Packet Data 
TransmutEnd does not have a return packet. 


Result Packet Data 


Result Quality | 
i 1 Byte 1 Byte 


Result - The Result field contains one of the following result codes: 
Code § Meaning 


NoErr Command successfully executed. 

InvalidErr | Command is invalid and cannot be executed. 

TOutErr A time out occurred. 

CommErr § Communication error occurred with the remote device. 
SystemErr The modem has had a fatal system error. 


Quality This 1-byte filed contains a value that indicates the quality of the 
transmission. A value of 1 indicates the image received at the target 
Station is acceptable. A value of 0 indicates the quality was poor and 
retransmission is required, possibly at a lower baud rate. 
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FaxReceive Command (command number 6) 


The FaxReceive command is issued by the host computer to prepare the AppleFax modem 
to accept a page of graphics data from the sending station. 


Command Packet Data 
None (0 bytes) 


Return Packet Data 
FaxReceive does not have a return packet. 


Result Packet Data 


The data field in the result packet contains 1 byte of result information. The possible result 
data are: 


Code Meaning 


NoErr Command successfully executed. 

InvalidErr | Command is invalid and cannot be executed. 

TOutErr A time out occurred. 

CommErr Communication error occurred with the remote device. 
f" NoImageErr No image is available to be received. 

. SystemErr The modem has had a fatal system error. 
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ReceiveBuffer Command 


(command number 7) 


The FaxReceive command return packet indicates whether or not a page of data is 
available. If the rerurn packet indicates a page is available, the host computer must execute 
ReceiveBuffer commands to begin transferring blocks of data from the modem buffer to 
the host computer. The ReceiveBuffer command must be executed often enough to keep 
up with the average rate of data coming from the transmitting station. If ReceiveBuffer is 
not issued often enough, you will receive the OverFlowErr code indicating that data has 


been lost. 


Command Packet Data 


The data field of the command packet consists of one 2-byte field used to indicate the 
number of bytes in the modem's receive buffer that are to be transferred to the host 
computer. The actual amount of data sent is indicated in the return packet data field. 


Return Packet Data 


Result 


Done 


| Result | Done Length Data —_ 
1 Byte 1 Byte 2 Bytes “nm Bytes 


a 


This 1 byte field consists of result information. The possible result 


data are: 

Code_ Meaning. 

NoErr Command successfully executed. 

InvalidErr | Command is invalid and cannot be executed. 

TOutErr A time out occurred. 

CommeErr Communication error occurred with the remote device. 
SystemErr The modem has had a fatal system error. 


OverFlowErr Some data has been lost due to buffer overflow 


This 1 byte field indicates if the current transmission is the last data 
transfer of the current image from the modem receive buffer. If it is the 
last transmission, the value of this field is 1. If this 1s not the last 


- transmission, the value is 0. 


This 2 byte field contains a value indicating the length of the variable 


data field that follows. 


This is a variable length field containing the actual data being sent to the 


host computer. 


Result Packet Data 


[Result | Done | 
|} | Byte 1 Byte | 


Same as Return packet data. 
Same as Return packet data. 
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ReceiveEnd Command (command number 8) 


When the host computer detects the Done flag set in the return packet of the ReceiveBuffer 
command, it executes a ReceiveEnd command to inform the modem whether or not the 
quality of the transmission is acceptable. 


Command Packet Data 


This field consists of 1 byte indicating the quality of the transmission. A value of 1 tells 
the modem the quality is acceptable. A value of 0 indicates the quality was not acceptable 
and a retransmission at a lower baud rate is necessary. 


Return Packet Data 
ReceiveEnd does not have a return packet. 


Result Packet Data 


The data field in the result packet contains 1 byte of result information. The possible result 
data are: 


Code Meaning 


NoErr Command successfully executed. 
a InvalidErr © Command is invalid and cannot be executed. 
( TOutErr A time out occurred. 


CommeErr Communication error occurred with the remote device. 
SystemErr The modem has had a fatal system error. 
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TransmitPacket Command (command number 9) 


When both the receiving and sending stations are AppleFax stations, the host computer 
issues the TransmitPacket and ReceivePacket commands to begin data transfer from one 
station to the other. 


Command Packet Data 


Length This 2 byte field contains a value that indicates the number of bytes in 
the following variable length data field. 
Data This variable length field contains data that is to be transmitted from the 


host computer to the other AppleFax station. 


a 


Return Packet Data 
TransmitPacket does not have a return packet. 


Result Packet Data | 
The data field in the result packet contains 1 byte of result information. The possible result 


codes are: 
Code Meaning. 
NoErr Command successfully executed. 


InvalidErr | Command is invalid and cannot be executed. 

TOutErr A time out occurred. 

CommErr Communication error occurred with the remote device. 
SystemErr The modem has had a fatal system error. 
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ReceivePacket Command (command number 10) 


When the modem receives a packet of data from another AppleFax station, execution of 
the ReceivePacket command will transfer the packet to the host computer. 


Command Packet Data 
None (0 bytes) 


Return Packet Data 
Result Length Data 
1 Byte 2 Bytes n Bytes 


Result The result field contains 1 byte of result information containing one of 
the following possible result codes: 


Code. Meaning. 

NoErr Command successfully executed. 

InvalidErr © Command is invalid and cannot be executed. 

TOutErr A time out occurred. 

CommErr | Communication error occurred with the remote device. 
IncompErr The remote device is incompatible. 

SystemErr The modem has had a fatal system error. 


Length This is a 2 byte field containing a value that indicates the number of 
data bytes contained in the following variable length data field. If no 
packets are available, the value of this field is zero. 


Data This variable length field contains the data from the remote AppleFax 
Station. 


Result Packet Data 
Same as the Return result field. 
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Disconnect Command (command number 11) 


When communication between the host computer and the target station is complete, the 
host computer issues a Disconnect command to close the connection and hang up the 
phone. | 


Command Packet Data 
None (0 bytes) 


Return Packet Data 
Disconnect does not have a return packet. 


Result Packet Data 


The data field in the result packet contains 1 byte of result information. The possible result 
data are: 


Code Meaning. 

NoErr Command successfully executed. 

InvalidErr | Command is invalid and cannot be executed. 
TOutErr A time out occurred. 


CommErr | Communication error occurred with the remote device. 
SystemErr The modem has had a fatal system error. 
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SetRegister Command (command number 12) 

This command is used to set the value of the modem register indicated in the register field 
of the command packet. Refer to Appendix C of the AppleFax Modem User's Guide for a 
list of the registers. | 


Command Packet Data 


Register Value 
1 Byte 2 Bytes | 


Register The value of this 1 byte field indicates the number of the register to be 
set. 
Value This 2 byte field contains the value the register is to be set to. The high 


order byte is first, the low order byte second. 


Return Packet Data 


The data field in the result packet contains 1 byte of result information. The possible result 


codes are: 
Code Meaning_ 


NoErr Command successfully executed. 
InvalidErr | Command is invalid and cannot be executed. 
SystemErr The modem has had a fatal system error. 


Result Packet Data 


Same as Return packet data field. 
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Reset Command (command number 14) 
This command is used by the host computer to reset the modem. This command overrides 


all other commands and will be executed even if another command is in process. The 
Reset command has no return or result packets. 


Command Packet Data 


None (0 bytes) 


Return Packet Data 


Reset has no return packet. 


Result Packet Data 


Not applicable: this command resets the modem before the result can be read. 
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GetRegister Command (command number 13) 


This command is used to get the value of the modem register indicated in the register field 
of the command packet. Refer to Appendix C of the AppleFax Modem User's Guide for a 
list of the registers. 

Command Packet Data 

The data field in this packet contains one 1-byte field that indicates the register number to 
be polled. 


Return Packet Data 
| Result Value | 
1 Byte 2 Bytes 
Result The data field in the return packet contains 1 byte of result information. 
The possible result codes are: 
Code Meaning 


- NoErr Command successfully executed. 
é InvalidErr | Command is invalid and cannot be executed. 
SystemErr The modem has had a fatal system error. 


Value This 2 byte field contains the value of the register indicated in the 
command packet. It is returned high byte first, low byte second. 


Result Packet Data 


Same as Return packet fields. 


32 AppleFax Modem Preliminary Notes 9/29/87 


Version Command (command number 16) 


The version command is used to provide the current ROM release information. ( 


Command Packet Data 


None (0 bytes) 


Return Packet Data 


Result ROM ROM 
Release | Version 
} Byte 1 Byte | Byte | 


Result This 1 byte field always contains the result code NoErr. 
ROM Release This 1 byte field contains the current ROM release level. 


ROM Version This 1 byte field contains the current version of the ROM release level. 


Result Packet Data 


The Result packet format is the sare as the Return packet format. 
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(— GetResult Command (command number 17) 


The GetResult command is a special command that is issued by the host computer to get 
the result data of the last completed command. The Command Packet Data field is empty. 
The Return Packet of the GetResult command contains the Result packet of the last 
completed command. The GetResult command does not effect the result buffer, therefore, 
the Result Packet Data is not used. Prior to executing the GetResult command, issue the 
Status command to ensure the previous command has completed. 
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PickUp Command (command number 18) 

The PickUp command is used to connect to the phone lines (for example, ‘pick up the 
phone’) and has no effect on data transfer. This command is normally used in conjunction 
with the HangUp command (discussed next) to ignore incoming calls. 


Command Packet Data 


None (0 bytes) 


Return Packet Data | 


PickUp has no return packet. 


Result Packet Data 


The Result packet contains a 1 byte Result field that always contains the result code 
NoErr. 


x 
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HangUp Command (command number 19) 


The HangUp command is used to disconnect from the phone lines . 


Command Packet Data 


None (0 bytes) 


Return Packet Data 


HangUp has no return packet. 


Result Packet Data 


The Result packet contains a 1 byte Result field that always contains the result code 


NoErr. 
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Modem Driver Technical Overview 


This section of the developer notes describes the user interface and functions of the 
sofrware for the AppleFax modem. 


The AppleFax modem driver will function only on the Macintosh 512 with enhanced 
ROMs, the Macintosh Plus, the Macintosh II, and the Macintosh SE computers. The 
driver supports both the group 2 and group 3 facsimile machines. If a target fax has both 
the group 2 and group 3 capabilities, the driver automatically selects group 3. For group 3 
fax machines, the modem driver supports one dimensional T4 run length encoding. The 
pixel width of a scan line for both group 2 and group 3 is 1728 bits. 


The AppleFax modem driver supports the standard high-level print manager and the low- 
level print manager. All of the high-level print manager functions supported are listed in 
Inside Macintosh, volume 2. The difference between those functions listed and the driver 
is that the modem driver always spools temporary print files to the disk while telling the 
calling application that it is in draft mode. The mandatory spooling 1s necessary to avoid 
data starvation problems. This means that the size of the document to be transmitted is 
limited to the available diskette space. The draft mode is used so that the application does 
not open and close the driver for every page. 


The modem driver also supports all of the low-level access calls, listed in Inside. 
Macintosh, volume 2, in order to support those applications that make low-level driver 
calls, such as MacPaint. 


The AppleFax driver does not support text streaming (transmission of ASCTI text 
characters), Postscript, or PrGeneral commands. 


User interface 
The user interface of the AppleFax modem driver utilizes three types of dialog boxes: 


co Style dialog 
co Job dialog 
c Set-Up dialog 


Throughout the descriptions of the dialog boxes, all selectable option fields are referred to 
as option. All action criented buttons, such as Send, Cancel, Open, and such are referred 
to as buttons. Descriptions of the different operations within these dialog boxes are in 
Chapter 2 of the AppleF ax Modem User's Guide. 

Style Dialog 


The Style dialog allows you to specify the imaging style of the transmitted document prior 
to transmission. Figure 4 shows the Style dialog box. 
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eemeanie 


sO A4 Letter 


--OUS Legat © International Fanfold Cancel | 
© Computer Paper 


Orientation Special Effects: @No Reduction 
} C 33 % Reduction 
© 66 % Reduction 


Figure 4: Style Dialog Box 


Following is a description of the options in the Style dialog box: 


Paper The same five paper size options available for the Imagewriter are 
also available for the AppleFax: 
¢ US Letter 8" x 11" 
¢ US Legal 8" x 14" 
¢ Ad Letter 8" x 11.67" 
¢ International Fanfold 8" x 12" 
¢ Computer Paper 8" x 11" 


The AppleFax modem driver currently supports the transmission 
mode of 1728 pixel width. Eventhough fax machines image at 200 
dpi (dots per inch), the AppleFax images at 216 dpi. This is due to 
the fact that the Macintosh screen is 72 dpi (dots per inch), and 216 
is the nearest even multiple of 72. The 216 dpi was chosen over the 
normal 200 dpi due to the bad effects, including staircasing, that 
occur when fractional image conversion takes place. Thus, an 11- 
inch document will be 11.88 inches after transmission; an 8-inch 
wide document will be 8.64 inches wide after transmission; and so 
on. 


Orientation The Orientation option allows you to specify the layout, upright or 


sideways, of your document prior to transmission. 


Special Effects The Special Effects option allows you the ability to specify one of 
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three image sizes prior to transmission. So that the images to be 
transmitted are the highest possible quality, the values for reduction 
are determined by multiplying the Macintosh screen resolution by an 
even amount. For example, the three immage sizes are 


¢ No Reduction 
© 33% (72 dpi * 2) 
¢ 66% (72 dpi* 1) 
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Job Dialog 
The Job dialog box is used to specify not only quality and quantity of the transmission, but 


also the destination phone number and an address book that contains a list of fax locations 
and numbers. Figure 5 shows the format of the job dialog box. 


= 
» . 


[| Send | 


AppleFax™ Resource 1081 
Quality: @ Best © Faster 


Page Range: @All OFrom:[ | to:[ | 


| Address book: Press ‘Open’ to get an address book... 


* 


| © Auto dial 
© Manual! dial 


Dial number: 


Figure 5: Job Dialog Box 


Following is a description of the Job dialog box options: : C 


Quality The Quality option allows you to specify the vertical resolution of 
_ either 200 Ipi (lines per inch) or 100 lpi. These options are 
represented as Best and Faster, respectively, in the dialog box. The 
100 Ipi vertical resolution is accomplished by transmitting only 
every other line to the target station. This method takes 
approximately half the transmission time as the 200 lpi method. 


Page Range The Page Range option is the same as that of the Imagewriter printer 
in that it allows you to specify all pages of a document for 
transmission or a range of pages within a document. 


Auto dial Selection of the Auto Dial option signals the driver to dial and 
connect with the target fax station automatically by using the number 
listed in the Dial number field when the Send button is clicked. 

Note that this option is mutually exclusive with the Manual dial 
option. 


Manual dial Selection of the Manual Dial option signals the driver to call up the 
| dialog box (shown in Figure 6) that tells you to dial the target fax 
station manually and to click the Send button when a carrier tone is 
detected. Note that this option is mutually exclusive with the Auto 
dial option. 
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( _ Manually dial the target fax machine's (Cx) ss 
phone number. Wait for the tone and press ss 


__ the 0K Button. 


Figure 6: Manual dial dialog box 


Dial number Selection of this field automatically selects the Auto dial option. The 
Dial Number field is the one you use to enter the telephone number 
of the target fax station. The field is 64 characters long and will 
accept digits 0 through 9 and the following characters: ,()-tTpP 
#*. For more information on these special characters, refer to 
Appendix C in the AppleFax Modem User's Guide. The characters 
t, T, p, and P are used to designate pulse or tone dialing. Including 
one of these characters at the beginning of the number string will 
override the option setting in the Options dialog box discussed later. 


Address book The address book field contains a list of names and numbers created 
by the AppleFax application. The driver uses the address book as a 
read only source of phone numbers. If you click on an entry in the 

oo address book, the number will be automatically entered into the Dial 

: number field. Once in that field, the number can be edited, if 

necessary. Any changes to the number while in the Dial number 

field will nor change the entry in the address book. To open an 
address book, click the Open button in the dialog box. 


Send The Send button is action-oriented in that when it is clicked or when 
the Return or Enter keys on the keyboard are pressed, all selected 
options in the dialog box are accepted by the driver and the 
document is transmitted. 


Save file Save file is an action-oriented button that is used to activate the 
standard Put File dialog box. This dialog box allows you to save 
the image generated by the driver in a specified destination file or 
folder. Clicking the Send button in the standard Put File dialog box 
will create a fax file and exit the job dialog box. Clicking the Cancel 
button in the Put File dialog box will return you to the job dialog 
box. 


Cancel The Cancel button is action-oriented in that it will ignore any options 


selected in the job dialog box and exit the fax operation being 
performed. 


9/29/87 AppleFax Modem Preliminary Notes 4| 


Open Open is an action-oriented button that invokes the standard Get file a 
dialog box (shown in Figure 7). The Get File dialog box lists the 4 
available address book files that are created by the AppleFax 
application. The address books contain commonly used names and 
numbers of frequently called fax stations. Clicking the desired 

= address book in the Get File dialog box will open that book into the 
address book field of the Job dialog box. 


-Domyfddresses.. 0) Pe Tester 


w 
| 


Figure 7: Get file dialog box 


Set up The Set Up button is used to invoke the Set Up dialog box, which is 
discussed in the following paragraphs. The Set Up dialog box 
allows you to specify the set up defaults information for a fax 
transmission. 


Help The action-oriented Help button calls up the Help dialog box that 
briefly describes the controls in the job dialog box. The Help dialog 
box is shown in Figure 8. 
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The Print Dialog lets you set Fax Modem print options. [ ox | 


nen nrg Sanam at A CR AER 


First, designate the desired print quality and page range. Neut enter 
the phone number of the device to which you want to send the fax in 
the ‘Dial number’ edit box. Hit the 'Send' button to start transmission. 


To save a Fax File for later transmission, press the ‘Save File’ button 
and specify the file name and folder in the ‘Save’ dialog. 


For manual dialing, set the ‘Manual dial' radio button, press the ‘Send 
button, and wait. After the document is made ready for Fax 

| transmission, a dialog will be displayed that will inform you to dial 
the number of the device that you want to contact. When you hear 
the tone press the ‘OK' button to connect with the device. 


Press the ‘Open’ button to access an address book. Clicking on an 
entry in the scrollable address book list will copy the entry's phone 
number to the ‘Dial number’ edit box. 


Press the ‘Set up’ button to specify default Fax options, such as pulse 
or tone dialing. 


Figure 8: Help Dialog Box 


Set Up Dialog 


As mentioned, the set up dialog box is entered by clicking the Set Up button in the job 
dialog box. The Set Up dialog box allows you to specify various fax-related set ups, such 
as the number of redial attempts, dialing mode, and a station ID number. Figure 9 shows 
the Set Up dialog box. 


pont aac t DASERT EEL PRIA A tht’ ene 


Dialing Mode: @Tone Pulse  Redials: fo | 


| Your phone # | 408 555-1212 


i] Send Station ID message 


Station ID | From: Allen The Bold Fax 


Figure 9: Set Up Dialog Box 
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Following is a description of the Set Up dialog options: 


ID Number The ID Number option field usually contains the phone number of 
the AppleFax station. This field is used to identify itself after 
connection to the target fax is completed. This message string can 


= be edited. 

Redials The Redial option field allows you to specify the number of times 
you wish the AppleFax modem to attempt a redial of the target fax 
station. 

Use station ID This option field allows you to specify whether or not the driver is 


to use the text contained in the Station ID field as an identification 
string across the top of every page transmitted. The default value of 
this field is ON. The format of the identification string is as follows: 


Station ID St MMM DD, YY,XX:XX_ Page Y 


Where Station ID Sr is the string contained in the station ID field of 
the Set Up dialog box. MMM DD, YY is the current date, XX:XX 
is the current time, and Page Y is the absolute page number. The 
date and time fields are obtained from the standard Macintosh 
international utilities [UDateString and JUTimeString. The time 
string used does not include seconds. 


Dialing mode The Dialing mode option field allows you to specify the default 
dialing mode of pulse dialing or tone dialing. If neither of the letter 
options p / P ort /T is specifed in the number string field of the Job 
dialog box, the setting of this field will determine the dialing mode. 


Station [ID This option field can be edited to specify any station ID string you 
wish to have printed on transmitted pages. 


Error Listing 


The AppleFax modem errors codes can be put into three catigories: 

c Errors that cause the AppleFax modem not to respond to AT commands 
o Errors reported by the application 

co Errors reported by the modem driver 


Each of these are discussed in the following paragraphs. When errors do occur, reset the 
modem using the FxCmdOpen command. 

No Response Alert 

If the AppleFax modem does not respond within 5 seconds after the AT initiate phase at the 
beginning of the transmission, the No response alert box is invoked (see Figure 10). This 


action indicates that the driver cannot communicate to the modem. The user can then 
attempt to reconnect or quit the application. 
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the connection and selection. Click OK to 


__ continue, Cancel to terminate printing. 


ip The Fax Modem is not responding. Check [ OK | | 


Figure 10: No Response Alert Box 


Error Numbers 


Error numbers are returned to the application in a print variable called PrErr. The 
application interprets the error numbers and reports the error to the user. The majority of 
the errors reported are the same as the errors for the Imagewriter driver. The fax-specific 
error numbers reported to the application are not defined yet and therefore, will be reported 
by the fax driver (see Fax specific errors which follows). | 


Fax-Specific Errors 
These errors, unlike the error numbers, are handled by the AppleFax modem driver. These 


types of errors are fatal and are reported to the user with an alert box, shown in Figure 11. 
Fax-specific errors fall into two types of categories: 


o Errors reported by the driver due to communication errors between the 
Macintosh and the modem. 
© Valid internal modem errors reported by the modem. 


Fax modem error: -421 (c | 
Pages sent to 2652: 0 [Cancel } 


A communication error occured between 


the Macintosh and the Fax Modem. Reset 
the modem and check your serial cable. 


Figure 11: Fax Specific Error Message Alert Box 


The Macintosh-modem communication errors are displayed by using a single 
communication error message box. The actual error number is displayed with the message 
to aid in troubleshooting, as well as the number of pages transmitted to the target fax station 
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before the error occurred. Errors reported by the modem are handled in two different 
ways: 


- If the internal error is in the firmware, the message "Internal modem error” 1s 
displayed with the corresponding error number. 

c If the error was generated by a process beyond the control of the firmware or 
software, such as a busy signal, a descriptive message and the corresponding 
error number are displayed. 


Fax specific errors are divided into three categories: 


5 Macintosh-modem communication errors. 
© Internal firmware errors 
© Errors due to external circumstances 


Each of these are described in the following paragraphs. 


Macintosh-modem communication errors: These types of errors occur due to a 
communication problem between the Macintosh and the attached AppleFax modem. The 
basic error message, reported by the modem driver, is the same for all errors and was 
shown in Figure 11. The following list contains the possible error numbers displayed with 
the message: : ; 


-420,FEInvid Invalid command attempted on the AppleFax modem. This 
error could mean either that there is a bad serial connection, 
or that an application has used a low level command that 
does not exist. 


-421,FENoResp No response from the AppleFax modem. Probable causes 
for this error are that the power is off, the serial cable is not 
connected, or the modem firmware is not functioning 


properly. 
-422,FECkSum A checksum error occurred in the response data received 


from the AppleFax modem. This error may be due to a bad 
serial connection. 

-423 FEBadCrl Driver received a bad control packet from the modem. This 
error may be due to a bad serial connection. 


-424,FEBadCon Modem has informed the driver that the last packet received 
by the modem contained a bad checksum. This error may be 
due to a bad serial connection. 


-425, FEBadLen Modem attempted to send the driver too many bytes for a 
given record structure. 


-426,FEModemTO If the modem takes too long to complete an operation, it 
results in a time out error. 
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Internal firmware errors: If an error in the firmware occurs, the driver displays the 
following message: 


"An internal error has occurred in the AppleFax modem. Reset the 
__modem and try again” 


Along with this message, an error code number will be displayed to aid in troubleshooting. 
These error code numbers are as follows: 
-410,FENoImage There is no image available to be received. 
-411,FESystem A fatal system error has occurred in the AppleFax modem. 
-412,FETooLong The packet received by the modem is too long. 
-413,FEOverFlow Some data has been lost due to buffer overflow. 


Errors due to external circumstances: This last type of fax specific errors are 
reported by the modem due to circumstances within the environment. Each error code 
number in this category has its own error message that is displayed in the alert dialog box. 
These messages and the corresponding error numbers are as follows: 


-401,FETimeOut "The AppleFax modem could not connect to the target 
device. Check your phone connections and number." 


-402,FEComm "A communication error occurred between the AppleFax 
modem and the target device. Please try again." 
-403,FEIncompat "The target device at the current number is incompatible with 


the AppleFax modem. Check your phone number." 


-404,FEWrgVers "The firmware in the AppleFax modem is incompatible with 
this version of the AppleFax resourse." 


Status Messages 


The status message dialog box is provided to inform the user as to what the driver is doing. 
Status messages will only be displayed if the hOpt ions parameter element DIgsOn is 
TRUE. This is the default setting, however, some applications accessing the driver at a 
lower level may turn the status dialog off. 


In the currently supported status messages listed next, n is the current phone number or 
station name; p is the current page number, and FileName is the name of the saved file. 


"Spooling fax file..." 


This message is displayed as the document is being spooled 
to the disk prior to connection 


"Spooling fax file. Do not dial yet..." 


This message is displayed in place of the previous message 
if you have selected the manual dial option. 
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"Preparing fax file for transmission: page p..." 


The fax file is being converted into a temporary T4 encoded 
file that will be unspooled after connection. 


"Attempting to connect with n..." 
This message is displayed while connection to the receiving 
station is being attempted. 


“Connection established with n..." 
Connection to the receiving station was successful. 


"Disconnecting from n..." 
AppleFax modem is disconnecting from the receiving 
station. 


"Saving fax image as FileName..." 
This message is displayed when the Save File option has 
been chosen. : 
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AppleFax Library 


Applications interfacing to the AppleFax modem can do so through one of two channels: 
either through the AppleFax library or the print manager. The library provides a 
convenient way for certain applications to access low-level firmware commands directly 
and provides a few useful high level functions as well. 


The library was created with MPW and can be linked to any MPW application. For general 
use of the library, the following PASCAL interface files must be included in your source 
code: 


a FaxIntf.p Contains the constants and structure definitions that are used in 
the library 
Q FaxLibIntf.p Contains the interface to the routines in the library 


When you use the AppleFax library, certain global data is automatically initiated. In order 
to initialize the global data that is used by the library, the first library call you must make is 
FxLiblInit: 


PROCEDURE FxLibInit; 
The global variable FaxGlobals .iPrErr contains the error code (or zero) for any given 
library command. It is the responsibility of the application to detect and handle errors. If 


an error is detected, the application must set FaxGlobals .iPrErr to zero prior to 
executing any further library commands. 


Library Firmware Routines 


As stated, the AppleFax library is provided to allow certain applications the ability to access 
all of the low level fax firmware commands (see FxCalls.p for sample source code). In 
order to perform fax commands, the following three operations must be executed: 


c AFxCmdoOpen call to allocate and initialize the overhead for subsequent calls. 
co FxCommand Calls to execute any fax commands. 
o AFxCmdClose call to deallocate the overhead for the calls. 


All three of these commands use the parameter of pFCR, which is a pointer to a fax 
command record. The structure of the fax command record TFaxCmdRec is defined 


under FaxIntf.p. Following is a description of each firmware routine along with its input 
and output parameters. 


FxCmdOpen 
The fax command open (FxCmdOpen) routine uses the following format structure: 


FUCTION FxCmdOpen(pFCR: pTFaxCmdRec; DoErrDlgs, 
DoStatusDlgs: BOOLEAN): INTEGER; 


Following is the input parameter for the FxCmdOpen routine: 
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DPrCR ~.DPOrt 


DoErrDigs 


DoStatusDlgs 


This parameter is used as a pointer to a SerialPair structure that must 
be supplied by the application, The FxCmdOpen call opens the 
serial driver to the currently established baud rate and handshaking 
for the AppleFax modem. Upon opening the serial driver, the 
inRef and outRef parameters of the SerialPair structure are set 
with the serial driver's reference numbers. If the parameter 
intInBuf is not nil, FxCmdOpen calls SerSetBuf to set an 
alternate read buffer pointed to by int InBuf with a length of 
inBufSize. If you do not want to use an alternate read buffer, 
you must set int InBuf to nil. Refer to Jnside Macintosh, volume 
2, for information on the serial driver. 


If this BOOLEAN is true, the library will display error messages 
just like the driver 


If this BOOLEAN is true, the library will display status messages 
just like the driver. 


Following are the output parameters for the FxCmdOpen routine: 


FaxErr 


PFCR” nPacket 


FxCommand 


If there is no error, this field contains zero. If the field contains 
another value, it indicates the error is either a general system error or 
a fax-specific error, as listed in FaxIntf.p. This error can also be 
checked in FaxGlobals.iPrErr. 


This parameter is used internally as a handle to memory to execute 
commands. It is automatically allocated and initialized by the 
FxCmdOpen call and the application should not modify its’ 
contents. 


The fax command routine uses the following format structure: 


FUNCTION FaxCommand(pFCR: pTFaxCmdRec): INTEGER; 


Following are the input parameters for the FxCommand routine: 


DFCR*.FaxCommand This parameter contains an integer constant that reflects the 


firmware command that is to be performed. Following is a list of 
the constants that must be used: 


FTStatus = 0; 

FTFaxDial = FTStatus +]; 
FTFaxAnswer = FTFDial +1; 
FTFaxXmit = FTFaxAnswer +1; 
FTXmitLine = FTFaxXmit +1; 
FTXmitEnd = FTXmitLine +1; 
FT FaxReve = FTXmitEnd +1; 
FTReveBfr = FTFaxRcve +1; 
FTReveEnd = FTRcveBfr +]; 
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pFCR* .nPacket 


DPFCR’.pPOrt 


PFCR* pOutput 


 pFCR. .pinput 


pidleProc 


FTXmitPkt = FT RcveEnd +1; 


FTRevePkt = FTXmitPkt +1; 
FTDisconnect = FT RevePkt +1; 
FTSetReg =FTDisconnect +1; 
FTGetReg = FTSetReg +1; 
FTReset = FTGetReg +1; 
FT Version = FT Cancel +1; 
FTGetResult = FT Version +1; 
FTPickUp =FTGetResult +1; 
FTHangUp = FTPickUp +1; 


This parameter is used internally as a handle to memory to execute 
commands. It is automatically allocated and initialized by the 
FxCmdOpen call; the application should not modify its contents. 


This parameter is used as a pointer to the user-supplied SerialPair 
structure initialized by the FxCmdOpen call. 


This parameter field is used as a pointer to the structure you want to 
send to the modem with the command. These structures are 
different for each command. If there is no output structure for the 
call you are making, use nil. See "Fax Modem Command Record 
Structure" under FaxIntf.p, in Appendix B. 


This parameter field is used as a pointer to the structure that you 
want to use to receive information from the modem. These 
structures are different for each command. If there is no input 
structure for the call you are making, use NIL. See "Fax Modem 
Command Record Structure" under FaxInt f.p, in Appendix B 


This parameter field is used as a pointer to an idle procedure that is 
to be executed while the driver is performing asynchronous 
operations. You can use the library routine PrAbortCheck that 
will look for a key sequence of the Command period (.). This key 
sequence signifies that the user has terminated the operation. If 
PrAbortCheck finds this, it places the print error constant 
iPrAbort (128) into the global FaxGlobals.iPrErr. 


Following are the output parameters of the FxCommand: 


FaxErr 


pFCR*.pInput~” 
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If there is no error, this field contains zero. If this field contains 
another value, it indicates the error is either a general system error or 
a fax specific error, as listed in FaxIntf.p. This error can also be 
checked in FaxGlobals.iPr&rr. 


If the fax command that you are executing returns data, the data is 
put into the Input structure that pInput points to. 
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FxCmdClose 


The fax command close (FxCmdClose) routine uses the following format structure. Note 
that there are no output parameters for this routine. 


PROCEDURE FxCmdClose(pFCR: pTFaxCmdRec) ; 


Following is the input parameter for the FxCmdClose routine: 


pFCR This parameter field is used to de-allocate the overhead for the calls. 


High-Level Firmware Routines 
The high-level firmware routines consist of FxDumpFile and FxConvertFile. 


FxDumpFile 


Fax dump file (FxDumpFile) is a high-level library routine that uses a combination of 
lower-level fax firmware calls and driver-imaging techniques to allow an application to 
transmit already saved fax files to a fax machine. FxDumpFile is used independently of fax 
firmware calls, which means that FxCmdOpen is not necessary for this routine to function 
properly. FxDumpFile automatically handles the dialing of the phone, the connection, 
group 2 and group 3 encoding, and imaging. The format for this routine is as follows: 


FUCTION FxDump(hPrint: THPrint; hOptions: THOpts; 
DoErrDlgs, DoStatusDlgs: BOOLEAN): INTEGER; 


where hPrint 1s a handle to a print record (structure THP rint) and hOptions isa 
handle is a handle to a user allocated fax options record (structure THOpts in 
FaxCInt f.p) to be used in the dumping process. 


Following are the input parameters for the FxDumpFile routine: 


hPrint This parameter is used as a handle to a print record. If you specify 
nil for this parameter, FxDumpF ile will automatically allocate, 
initiate, use, and deallocate its own print record. However, if you 
want to use your own print record, you must call the library routine 
F1lPrintDefault in order to set up the print record prior to 
calling FxDumpFile. 


hOptions This parameter is used as a handle to user allocated fax options 
record (see Appendix B, structure THOpts under FaxIntf.p) 
that is to be used in the dumping process. Included in resource file 
FxLib-rsrc is a resource containing the HOptions. This resource 
type is ‘FOPT’ with a resource ID of -8191. The following list 
contains the option fields in the hOptions record: 
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Retries. This field contains an integer that specifies the number of 
times the library attempts to retry transmission before reporting 
errors. | 
ManualDial. This is a boolean for manual-dialing mode. Manual 
dialing is currently not available through the library, therefore this 
option is ignored. 

ModeFlg: .This field contains a 1-byte string that is used to specify 
the dialing mode of tone or pulse using the characters ¢/ T and p/P, 
respectively. 

DialNumStr. This field contains the string used to specify the 
telephone number of the target station. 

IDNum. This field contains the identification information that is 
used during the handshaking process with a fax machine. The 
contents of this field must be no more than 20 characters and contain 
only ASCII numbers or spaces. This field usually contains the 
phone number of the telephone attached to the AppleFax modem. 
StationID. This field contains a message that is to be imaged at the 
top of the each transmitted page. 


DoSID. Set to TRUE, this boolean indicates that the StationID is to 
be imaged. 

StationName: This string contains the name of the target fax station 
and is displayed in the status window. 

SaveFileRec. This record is used internally to save fax files. 
AddrBookRec: This record is used internally to keep track of the 
location of the most resently used fax address book. 

pFileChain: This record points to the first element in a queue of file 
description records of the files to be transmitted. Following are the 
elements of this record: 


cFLink Pointer to the next TFxFileChain file record. If it 
is the last record, this element is NIL. 

cFName File name string. 

cVRefNum Volume reference number of the file. 

cDirID ID of the directory to find the file. 


DoErrDigs: If the BOOLEAN is true, this library displays the error 
messages just like the driver. 

DoStatusDigs: If this BOOLEAN is true, the library displays the 
status messages just like the driver. 


Following is the output parameter for the FxDumpFile routine: 


FaxErr 
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If there is no error, this field contains zero. If the field contains 
another value, it indicates the error is either a general system error 
(as defined in Inside Macintosh) or a fax-specific error, as listed in 
FaxIntf.p. This error can also be checked in 
FaxGlobals.iPrErr. 
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FxConvertFile 

The fax convert file (FxConvertFile) library command is used to allow the application to 
convert a group 3 / T4 or group 2 encoded file to the standard fax file format. This call 
assumes that the application has used low-level fax firmware commands to receive raw 


encoded data from a fax machine and then stored the data with the file format. This call can 
be made as shown below: 


FUNCTION FxConvertFile (pinFile,pOutFile: pTFxSaveFile) : 
Where both the pInFile and pOutFile are pointers to TFxSaveFile records that 
specify the input and output files. It is not necessary for the output file to exist prior to 
calling this routine since FxConvertFile creates the output file automatically. 
General Routines 
This routine is used to default a user's print record: 

PROCEDURE FlPrintDefault (hPrint: THPrint): 


The General routine can be specified as an idleProc that looks for the Command, Shift, and 
Period keys to be pressed: 


PROCEDURE PrAbortCheck 


File Structures 


The following description of the AppleFax file structure assumes that you have a good 
understanding of the Print Manager and QuickDraw (see /nside Macintosh, volumes 1 and 
2). 


Fax File Format 


The AppleFax modem transmits and receives fax files. Fax files are created by the driver 
and contain header and page break information followed by a series of pages in Pict format 
(refer to Macintosh File Format and Picture Structure Graphic Applications, published by 
Apple Computer July 15, 1987). The format of the header in a fax file is a TPfHeader 
structure defined in the PASCAL include file MacPrint.p. The header contains a print 
record (TPrint) followed by the page directory structure TPfPgDir. The page directory 
consists of an integer, specifing the number of pages in the file, and an array of longints 
that specify the offest from the begining of the file to the start of each page. Figure 12 
shows the format of the fax file header. 


| TPrint integer | Picture Offset 
| 2 Bytes 128 4-byte fields 


Figure 12: Fax File Header Format 
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Each page contains a rectangle, RPage, that specifies the drawing area of the pict for that 
page. The 10 bytes following the page rectangle are fake overhead bytes used for the 
PicHandle. The variable field following these 10 bytes are the bytes of the picture itself. 
Figure 13 shows the format of the picture. Since fax files are basically pictures files, you 
can call DrawPicture to image the pages on the screen or dump them to printer grafports. 


RDirty Overhead Picture 
16 Bytes 10 Bytes n Bytes 


Figure 13: Fax File Picture Format 


Drawing a Fax File Picture 


The rectangle RPage in the PrinfoPt record of the TPrint record in the header of the fax file 
specifies the rectangle that is used in your call to DrawPicture. Note that the rectangle size 
is intended for imaging faxes at 216 dots per inch. Therefore, if you want to display a fax 
file on the screen at 72 dpi, you must divide the rectangle by 3 before calling DrawPicture. 
In order to draw a picture from an existing fax file, you must use the page directory to 
locate the beginning of the page. The rectangle at the beginning of each page description 
7 specifies the minimum imaged area within RPage. For example, if the page has a drawing 

= only in the upper portion of the page, the RDirty rectangle is used for internal optimizations 

( ee . 

‘ and you can ignore it. Prior to calling DrawPicture, you must do the following 
manipulation involving a QuickDraw bottleneck: 


1) Create a Pichandle that is 10 bytes long 
2) Read the 10 bytes following the RDirty rectangle into this handle. 


The data in this handle is required as Picture overhead for DrawPicture. The actual data for 
the picture is supplied by switching the quickdraw bottleneck 'GetPicProc' to point to your 
procedure that reads the picture data from the file upon demand from quickdraw. 
Temporary T4 File 

Each file that is to be transmitted to a fax station has a temporary file created using the T4 


file format. This format is defined for the sake of completness since no user accessable 
routines are contained in the library to handle this file format. 
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The temporary file is stored as a series of lines represented as word data lengths followed ao 
by T4 data: ( 


<word> length of line, <block> T4 line data 


<word> length of line, <block> T4 line data 
<word> Page break (iSNewPage) or last page (iSLastPage) 


Constants are used to indicate page breaks and last page. Note that there are no page break 
constants at the beginning of the file. 


Received File 


To convert received fax data into the previously described fax file format, you can use the 
library command FxConvertFile. To do this, you must first organize your fax encoded 
data into a packet format. These packets consist of an integer that specifies data type, an 
interger indicating the length of the data, and the data itself. The constants for the data 
types are defined in FaxIntf.p. — 


The header information expected at the beginning of each file is as follows: : 


Type Length Data 

REFCapabilities sizeof(SFIRec) Capabilities record SFIRec 
received using the FaxAnswer 
command. 

REFSIDStr sizeof(SIDStr) Station ID string received 
using the FaxAnswer 
command. 


The following information is required to describe each page: 


Type Length Data 

REFPageS tart len of data received Data received using 
ReceiveBuffer command. 

REFPageData len of data received Data received using the 
ReceivBuffer command. 
Repeat until entire page is 
received. 


To specify the end of the last page of fax transmission, use the following information: 


Type Length Data 
REFLastPage 0 none 
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Appendix A 


-- Capabilities and Result Formats 


(For FaxDial and FaxAnswer Commands) 


This appendix describes the format of the Capabilities and ResultCap fields used in the 
FaxDial and FaxAnswer commands. Both of these are variable length fields containing 
a string of data preceded by a length byte. The maximum length of these fields must not 


exceed Cap 


Size (8 bytes). 


The following table gives the contents of the first four bytes (bytes 0, 1, 2, and 3) 
following the length byte. Bytes after byte 3 are not yet defined by the T.30 standard. 
Following the table is a description of the bits and their values in more detail. 
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Capabilities (1.30 DIS 


Group 1 Capabilities 
Group 2 Transmitter 
Group 2 Receiver 
Reserved Group 2 bits 


Group 3 Transmitter 
Group 3 Receiver 


Data signalling rare 


V.27 ter fallback mode 
V.29 

V.27 ter 

V.27 ter and V.29 


Reserved for future group 
7.7 lines/mm. (200 Ipi) 
2-dim. coding capability 
Recording width capabilities 


1728 pixels 

1728 or 2048 pixels 

1728, 2048, or 2432 pixels 
Invalid 

Recording length capability 


A4 (297 mm.) 

A4 (297 mm.) and B4 (364 mm.) 
Unlimited length 

Invalid 


Scan line time capability 


20ms @ 100 lpi/20ms @ 200 Ipi 
Sms @ 100 lpi/sms @ 200 Ipi 
10ms @ 100 lpi/10ms @ 200 lpi 
20ms @ 100 lpi/10ms @ 200 Ipi 
40ms @ 100 Ipi/40ms @ 200 Ipi 
40ms @ 100 lpi/20ms @ 200 Ipi 
10ms @ 100 Ipi/Sms @ 200 Ip1 
Oms @ 100 Ipi/Oms @ 200 Ipi 
Extend field 


Unsupported by the Fax Modem 
Extend field 
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Group 1 Capabilities 


Receive Group 2 
Reserved Group 2 bits 


Receive Group 3 
Data Signalling Rate 


2400 bps V.27 ter 
9600 bps V.29 
4800 bps V.27 ter 
7200 bps V.29 


Reserved for future group 

7.7 lines/mm. (200 Ipi) 
2-dimensional coding 

Recording width 

1728 pixels 
2048 pixels ” 
2432 pixels 

Invalid 

Maximum recording length 


A4 (297 mm.) 

B4 (364 mm.) 
Unlimited length 
Invalid 

Maximum scan line ame 


0 ms 
Extend fieid 


Unsupported by the Fax Modem 
Extend field 
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Byte 0, Bits 0-2: Group 1 Capabilities 


Group 1 is not supported by the AppleFax modem. These bits should be set to 0 in the 
Capabilities field and ignored in the ResultCap field. 


Byte 0, Bit 3: Group 2 Transmitter 
Byte 0, Bit 4: Group 2 Receiver 
Byte 1, Bit 0: Group 3 Transmitter 
Byte 1, Bit 1: Group 3 Receiver 


In the Capabilities field, these bits enable the controller to specify its capabilities to the 
remote device. The controller sets the bits according to its capabilitites. 


In the ResultCap field, these bits are used to tell the controller which operations have been 
selected from the point of view of the remote device. The following table lists how the 


selected operations will be indicated: 
Operation . 3 Bit Set 
Group 3 transmission from controller to Group 3 Receiver, bytel, bit 1 
remote device 
Group 3 reception from remote device Group 3 Transmitter, bytel, bit 0 
to controller 
Group 2 transmission form controller to Group 2 Receiver; byte 0, bit 4 
remote device 
Group 2 reception from remote device Group 2 Transmitter, byte0, bit 3 
to controller 


If both group 2 and group 3 capabilities are available, group 3 operations will have priority 
and be selected over group 2 operations. | 


Byte 1, Bits 2,3: Transmission Speed Capabilities 


The AppleFax modem is capable of transferring data over the phone lines at four different 
data rates: 9600, 7200, 4800, and 2400 bps. Other fax modems have some subset of 
these data rates available. In certain rare situations, it may be desirable to make the fax 
modem restrict its operation to a subset of its available data rates. Bits 2 and 3 of byte | in 
the Capabilities field allow this type of restriction to be controlled. The possible data rate 
restriction settings are as follows: 


Bits 3.2. _ Restrict 


0,0 2400 bps 

0,1 9600 or 7200 bps 

1,0 4800 or 2400 bps 

1,1 9600, 7200, 4800, or 2400 bps 


The last subset allows full functionality. 
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In the ResultCap field, the fax modem returns the data rate that will ate be used for the 


data transfer. The bit values for each data rate are given below: ( 
Bits 3.2 Data R 
0,6 2400 bps 
0,1 9600 bps 
1,0 4800 bps 
1,1 7200 bps 


No matter what data rate the modem uses over the phone line, data will always be 
transferred between the controller and the modem at the currently selected baud rate 
(typically 19,200 baud). 


Byte 1, Bit 6: Vertical Resolution 
In the Capabilities field, this bit specifies 200 lpi capability. 


In the ResultCap field, this bit specifies whether 200 Ipi resolution (value of 1’ . or 100 
lpi resolution (value of '0") will be used for the transmission. 


Byte 1, Bit 7: Two-Dimensional Coding 


In the Capabilities field, this bit specifies that the controller has two-dimensional coding ( 
capability. 


In the ResulrCap field, this bit specifies whether two-dimensional (value of '1') or one- 
dimensional (value of '0') coding will be used for the transmission. 


Byte 2, Bits 0,1: Recording Width 
In the Capabilities field, these bits specify the controller's image width: 
Bits 1.0 Image Width 


0,0 1728 pixels 
0,1 2048 pixels 
1,0 2432 pixels 
1,1 Invalid 


In the ResultCap field these bits specify which width is to be used for the transmission: 
Bits 1,0 Image Width 


0,0 1728 pixels 

0,1 1728 or 2048 pixels 

1,0 1728, 2048, or 2432 pixels 
1,1 Invalid 
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Byte 2, Bits 2,3; Recording Length 
In the Capabilities field these bits specify the controller's image length: 


Bits 1.0 Image Length 


0,0 A4 (297 mm) 

0,1 A4 (297 mm) and B4 (364 mm) 
1,0 Unlimited length 

1,1 Invalid 


In the ResultC ap field these bits specify which length will be used for the transmission: 
Bits1.0 Image Length 


0,0 A4 (297 mm) 
0,1 B4 (364 mm) 
1,0 Unlimited length 
1,1 Invalid 


Byte 2, Bits 4-6: Minimum Scan Line Time 


( In the Capabilities field, these bits specify the minimum time the controller needs to 
: process each line of a received graphic image: 
Bits 6.5.4 
0,0,0 
0,0,1 5 ms for 100 Ipi, 5 ms for 200 lpi 
0,1,0 10 ms for 100 Ipi, 10 ms for 200 Ipi 
0,1,1 20 ms for 100 Ipi, 10 ms for 200 lpi 
1,0,0 40 ms for 100 lpi, 40 ms for 200 lpi 
1,0,1 40 ms for 100 lpi, 20 ms for 200 lpi 
1,1,0 10 ms for 100 lpi, 5 ms for 200 lpi 
1,1,1 0 ms 


Some of these settings allow lines to be sent twice as fast when 200 lpi vertical resolution 
is being used. 


In the ResultCap field, these bits specify how much time is to be allocated for sending 
each line: 


Bits 6.5.4 Minimum Time per Line 


0,0,0 20 ms 
0,0,1 5 ms 
0,1,0 10 ms 
1,0,0 40 ms 
1,1,1 O ms 
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Byte 2, Bit 7: Extend 


This bit must be set to extend the record's length to four bytes. 


Byte 3, Bits 0-6: Ignored 
These bits are ignored by the fax modem in the Capabilities field. 
In the ResultCap field, these bits are passed directly from the remote device. 


Byte 3, Bit 7: Extend | 
This bit must be set to extend the record's length to five bytes. 


Examples 
Following are some examples of the previously described bit settings. 
Example 1 


This example allows 200 line per inch group 2 or 3 reception or transmission at any 
available baud rate. 


Byte 0: 

Group 2 transmission | $08 
+ Group 2 reception; $10 
= Byte 0 $18 
Byte 1: 

Group 3 transmission $01 
+ Group 3 reception $02 
+ V.27 and V.29 capability $0C (9600, 7200, 4800, or 2400 available) 
- 200 Ipi $40 
> One dimensional coding $00 
= Byte 1 S4F 


Z 
1728 pixel recording width 4$00 


+ Unlimited recording length $08 
+ 0 ms minimum line time $70 
= Byte 2 $78 
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The capabilities string (including the length byte) should be set to: $03, $18, $4F, $78 


Example 2 


This example allows 100 line per inch group 2 or 3 reception or transmission at any 
available baud rate. 


Byte 0: 

Group 2 transmission $08 
+ Group 2 reception $10 
— Byte 0 $18 
Byte 1: 

Group 3 transmission $01 
+ Group 3 reception $02 
+ V.27 and V.29 capability $0C (9600, 7200, 4800, or 2400 available) 
+ 100 Ipi $00 
+ One dimensional coding $00 
= Byte 1 SOF 
B 


Z + 3s 
1728 pixel recording width $00 


+ Unlimited recording length $08 
+ O ms minimum line time $70 
= Byte 2 $78 


The capabilities string (including the length byte) should be set to: $03, $18, SOF, $78 


Example 3 


This example allows 200 line per inch group 3 reception or transmission at a restricted 
baud rate of 4800 or 2400 bps. 


Byte 0: 

No group 2 capabilites $00 
= Byte 0 | $00 
Byte 1: 

Group 3 transmission $01 
+ Group 3 reception $02 
+ V.27 capability $08 (4800 or 2400 available) 
+ 200 lpi $40 
+ One dimensional coding $00 
= Byte 1 $4B 
Byte 2 


1728 pixel recording width $00 


+ Unlimited recording length $08 
+ 0 ms minimum line time $70 
= Byte 2 $78 


The capabilities string (including the length byte) should be set to: $03, $00, $4B, $78 
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Appendix B 


AppleFax Library Interface Code 
(File FaxIntf.p) 


Appendix B provides you with a hard copy of the AppleFax library interface code file 
Faxintf.p. 
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Faxintf.p ‘a 
x Modem driver includes ‘ 


Appendix A of the Fax Modem Driver Specification 


Copyright (C) 1986, 1987 
Apple Computer Inc. 
ALL RIGHTS RESERVED 


First Writing: 
O7=-NOV=-86:; P. Allen Cronce 


Modification history: 
PAC / 11-MAY-87: Updated for new firmware specs 
PAC / 15-AUG-87: new firmware commands 
PAC / 22-SEP~87: Modified THOpts to handle file list 


UNIT FaxiIntf 


Se 


INTERFACE 

See ee Se ene ee ae eS ae a ee Tatese essa Hsien ses S= Se Ses } 

USES 
{SLOAD MacIntf.LOAD} re : 

MemTypes, QuickDraw, OSIntf, TooliIntf£, PackiIntf: = 

{ SLOAD } 

{ > 8p OP GD GP GR GD GD GD GP GP GF OP OO GH @ Gh aR PLO NE SP AD SO OP AD ED AD ED ED ED EE DO OOOO 8 OO SOO SOOO OO OOO } 

CONST 


{ current version of the firmware that will work with this driver} 
iCurFirmLevel = 20; 


{time constants} 
OneSec = 60; { number of ticks in one second } 
OneMin = OneSec * 60; ( number of ticks in one minute } 


{ Fax timeout tickcount constants )} 


FATTimeOut = OneSec * 5; { 5 second attention time out } 
iFaxDialTo = OneMin * 2; { FaxDial time out } 

iFaxxXmitTo x OneMin * 1; { FaxTransmit time out } 
iBleedDtaTO = OneSec * 45; { firmware data bleed timeout } 
iXmitEndTO = OneSec * 20; { TransmitEnd time out} 
idisconnectTO = OneSec * 20; {-Disconnect time out} 
iFaxAnswerTO = OneMin;: {1 minute - FaxAnswer} 

iFaxRecvTO = OneMin; {1 minute - FaxReceive} 

LiRecvEndaTO = OneMin * 2; (4 minute - ReceiveEnd} 

iXmitPkeTto = OneMin: {1 minute - TransmitPacket } 
iRecvPktTO = OneMin; {1 minute - ReceivePacket } 

iGetRegTO = OneSec * 5; {S seconds - get reg} 

iSetRegTO = OneSec * 5; {5 seconds - set reg} 


{ Horizontal resolution } 
FPixleWidth = 1728: 
FByteWidth = 216; {FPixleWidth DIV 8} 


ome 


Group 2 capabilities } 
{ In SFIRec.data(0] } 


G2_Transmit = 8; { Can transmit group 2 } 
G2_Receive = 16; { Can receive group 2 } 
G2_I0C176 = 32; { IOC = 176 rather than 264 } 


G2_ReceiveTst = 4; {for bit tst) 
G2_TransmitTst = 3; (for Dit tse) 


{ Default group 2 capabilities: } 
G2_Default = (G2_Transmit+G2_Receive) ; 
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{ Group 3 capabilities } 
{ In SFIRec.data(1l]} } 


G3_Transmit = 1; { Can transmit group 3 } 
G3_Receive = 2; { Can receive group 3 } 
G3_V27slow = 0; { Can only use V.27 2409 bps } 
G3_Vv27 = §; { Can use V.27 2400 or 4800 bps } 
G3_v29 se oe { Can use V.29 7200 or 9600 bps } 
G3_V27_V29 = 12; { Can use V.27 or v.29 } 


G3_2400 = 0; { Using V.27 2400 bps } 

G3_ 4800 = 8; { Using V.27 4800 bps } 

G3_7200 = 12? { Using V.29 7200 bps } 

G3_ 9600 =a; { Using V.29 9600 bps } 

G3_200lpi = $40; { 200 lpi rather than 100 } 

G3_100lpi = SBF; { and this with capabilities to clear 200 lpi } 
G3_200lpiTst = 6; { bit position number for btst } 

G3_2dim = $80; { Two dimensional encoding } 


{ In SFIRec.data(2] } 


G3_W1728 = $00; { Maximum width of 1728 pixels } 
G3_W2048 = $01; { Maximum width of 2048 Pixels } 

G3_W2432 = $02; { Maximum width @f 2432 pixels } < 
G3_LA4 = $00; { Maximum length: A4 size } 

G3_LAny = $08; { Maximum length unlimited } 

G3_LB4 = $04; { Maximum length: B4 } 

G3_0ms = $70; { Minimum scan line times in milliseconds } 
G3_5ms = $10; 

G3_10ms = $20; 

G3_20ms = $00; 

G3_40ms = $40; 

G3_il0msHalf = $60; { Minimum line times. In high } 

G3_20msHalf = $30; { resolution mode, time can be } 

G3_40msHalf = $50; { decreased by half. } 

G3_Extend = $80; { extend field. } 


{ Default group 3 capabilities: } 
G3 Default = (G3_Transmit+G3_Receive+G3_V27_V29+G3_W1728+G3_LA4+G3_Oms) ; 


oo! 


Mode specifiers: } 
{ Act like a standard Fax machine. } 
Standard = Q; 


{ Act like a standard Fax but identify as an AppleFax. } 
Limited = 1; 


{ Use AppleFax mode if both sides are AppleFaxs. } 
App leFax = 2; 


{ Fax command / response types } 


FTStatus = Q; 
FTFaxDial = FTStatus 1 
FTFaxAnswer = FTFaxDial Le 
FTFaxXmit = FTFaxAnswer same 
ETXmitLine = FTFaxxmit oy 
FT XmitEnd = FTXmitLine ES 
ye FTFaxRcve = FTXmitEnd + 13 
i FTReveBfr = FTFaxReve + Ls 
i FTReveEnd = FTReveBfr + 1; 
FTXmitPkte = FTReveEnd +: +15 
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FTRevePke 
FTDiseonnect 
FTSetReg 
FTGetReg 
FTReset 
FTCancel 
FTVersion 
FTGetResult 
FTPickUp 
FTHangUp 


rers } 
ErrBase a= 
NoErr 

Executing = 


= 
E 
v 
unt 
~ 
= 


= FTXmitePke 

= FTRevePkt 

= FTDisconnect 
= FTSetReg 

= FTGetReg 

= FTReset 

= FTCancel 

= FiVersion 

= FTGetResult 
= FTPickUp 


-400; 


0; 


Ye 


=? 
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Se ®e Yo %e 


Se Se 


+ + t+ + t+ + t+ t+ +t 


MRR Re Rr eR ee 
Re 


{base error added to other errors for uniqueness} 
{no error} 


(Firmware reported errs due to external circumstances} 


FETimeOut = 
FECommErr = 
FEIncompat = 
FEWrgVers = 


-1; 
-2; 
-3; 
-4; 


{Time out error} 

{Communication error with the target device} 
{target device is incompatible} 

{wrong version of the firmware for the software} 


{Firmware reported internal system errors} 


FENoImage = -10; {no image is available to be received} 
FESystemErr = -ll; {fatal internal system error} 
FETooLong = -12:; (modem received a packet that was too long) 
FEOverF low = -l13; (buffers were not read by the driver fast enough} 
(Firmware reported errs due to modem / driver problems } a 
FEInvid = -20; (Invalid command and cannot be executed} 


{software driver reported errors when the modem is flaked} 


FENoResponce = -21; {No responce from the fax modem} 
FECkSumErr = -22; {chksum error in the responce data received} ( 
FEBadCtrl = -23; {bad contrel packet returned} 

FEBadComfirm = @24; {bad comfermation of sent packet} 

FEBadLength = -25; {modem tried to send too many bytes} 

FEModemTO = =-26; {modem is taking too long} 


{ This error happens if the dialogs are turned off and manual dial is used } 
FeOufusErr = ~-29; { the user is a dufus } 


{software driver reported errors when performing T4 data conversion} 


FET4InEmpty = <-31; {empty input buffer} 
FET4OutFull = -32; {output buffer full) 


FET4DataErr = -33; {data syne error} 


( Error cede ranges } 
{ All errors } 
FEFirst « FPETimeOut> 
FELast = FPEDufusErr; 


{ problems between modem and me } 
FENoComFirst = FEInvld; 
FENoComLast = FEModemTO; 


firmware reported errors due to external circumstances } 
FEXFirmFirst = FETimeOut; 
FEXFirmLast = FEWrgVers; 


( firmware reported errors due to internal problems } 
FEIFirmFirst = FENoImage; 
FEIFirmLast = FEOverf low: 


{ generic cancel alert } 
iCancelAx = -8183; { PAC / General purpose cancel alert } 


{Error message string res numbers} 
iinternErrcstr = ~-8179; {generic intenal error} 
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LMMComErrStr 


LATMsgBaseStr 
iTimeOutStr 
iComErrStr 
iIncompatStr 


{status dialog} 
iPrStatDlg 


{STR# constants 

iStatStrResID 

IStatitem 
{indices into 
isPrep = 
isMDPrep = 
isAtmptCon = 
isConnected = 


isxXmitPage = 
isDiscon = 
isSaving = 
isManual = 
isTo = 
isPage = 
isDots = 
isMPCancel = 
isPagesSent = 
isError = 
isSpoolT4 = 
isFaxNum = 
isRetry 2 


isIniting = 


= -8180; {generic Mac / modem communication error} 


= -8180; (base messages for external error reporting} 


=z LATMsgBaseStr + FETimeOut; {Time out error} 

= LATMsgBaseStr + FECommErr; {Com error with target} 

= LATMsgBaseStr + FEIncompat; {target is incompatible} 
= -8190; 


for status messages} 

= ~8190; {resource ID of our STR#} 

a5 
the strings within this res} 
is 
isPrep 
isMDPrep 
LsAtmptCon 
isConnected 
isXmitPage 
isDiscon 
isSaving 
isManual 
isTo 
isPage 
isDots 
isMPCancel 
isPagesSent 
isError 
isSpoolT4 
isFaxNum 
isRetry 


=e ee ee eo Re Re 


ws 


Be Qs e Se 


ete ese Xe me es 


++ eee eereetettrer tet tt 
PRPRPRPrP RPP PRPRPrPrRPrP rr rr 


we 


{ resource type of the fax options } 


FxOptsType = 


"FOPT'; 


{ Fax file type and creator } 


LF xType == 
{1LFxSig = 
LFxSig = 


{length constants 


iCapSize = 
LIDNumSize = 
iAFISize = 
iPNumSize = 
iTIDSize = 


(‘Extended status} 
iXSXmitDone = 


(File buffer size 


§46465846; ("FEXE"} 
$46535953;} ("ESiTS"} 
$46414658; {"PAFX"™} 


for Fax firmware commands} 
8; 
22; 
64; 
64; 


26; {Terminal identification string} 


$01: {Modem has finished transmitting) 


for PicFile State Object} 


iFxIOBlLkBytes = 512; 


{Library constants 


) 


(raw encoded file packet types} 


REFCapabilities 

REFSIDStr 

REFPageStart 

REFPageData 

REF LastPage 
iStationName = 20 
iPhoneNumber = 20 
iPassword = 20 


iFileName . = 64; 


= Q; {capabilities} 

= il; {Station id string} 
= 2; {start of the page} 
= 3; {the page} 

= 4; {terminator} 
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ivolName = 30; 

iMachType = 3; 

Via = iStationName; “ 
iTimeStr = Ss ( 

LOTR RM me eee eee ee ee eee } 

TYPE 


TStationNameStr = STRING(iStationName]; 


TPasswordaStr = STRING(iPassword]; 

TrileNameStr = STRING (ifileName]; | 

TVolNameStr = STRING(iVolName]; | 
bufPcr = Per; | 
uchar = SIGNEDBYTE; | 

{----- Internal fax packet protocol structures --<<------.---. 2 } 


(Fax packet header} 
FPHeader = PACKED RECORD 
CmdType, 
HiLlen, 
LoLen, 
CkSuml: uchar; 
END; 


(Pointer list record) : “ 
PterListRec = PACKED RECORD - 
Length: INTEGER; 
thePtr: bufPtr; 
ENC; 
pPtrlistRec = “PtrListRec; 
hPtrListRec = “pPtrhlistRec; 


(This structure simplifies use of the serial ports by grouping the 
=nput and output ports and buffer pointers.} 
SerialPair = PACKED RECORD 


inRef: INTEGER; {serial input reference number} 
outRef;: INTEGER; {serial output reference number} 
inBufSize: INTEGER; (size of the alternate input buffer (optional) } 
intInBuf: BufPtr; {pointer to ser input buffer, if any} 
END; 


pSerialPair = *SerialPair; 


{ Fax packet protocol record } 


FaxPacket = PACKED RECORD 
Header: FPHeader; 
NumOutPtrcs: INTEGER; { Number of pointers in the pointer list } 
hOutPtrs: hPtrListRec; { Hdl to list of pers that define the dta bfr } 
NumIinPtrs: INTEGER; { Number of pointers in the pointer list } 
hinPtrs: hPtrListRec; { Hdl to list of ptrs that define the dta bfr } 
CkSum2; INTEGER; { checksum of data } 
LastCmd: INTEGER; { last executed command } 

END; 


PFaxPacket = “*FaxPacket; 
hFaxPacket = “pFaxPacket;: 


{ record to store the memory management states of a packet protocol record } 


FStateRec * PACKED RECORD 
Packet, { packet mem state } 
OutPtrLst, { output pointer list state } 
InPtrLst, { input pointer list state } 
Fila: uchar; 
END; 
{-e=- General Fax command structures -----<---------- oe we wee ween ecw men oo woe re 


{Strings} 
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IDNumStr = STRING[(iIDNumSize - 1]; 
pIDNumStrc = “TDNumStr; 


TIDStr = STRING(iTIDSize - 1]; 
pTIDStr = “TIDStr; 


PNumStr = STRING(iPNumSize - 1]; 


{Standard Fax Info: contains information about the capabilities of standard 
group 2 and group 3 fax machines. [It is a variable length string preceded by 
a length byte, but in normal applications only 3 bytes are required. 
Advanced applications may wish to use more bytes.} 

SFE TRec = ARRAY [0..iCapSize-1] OF uchar; { the bytes } 

pSFIRec = “SFIRec; 


{Apple Fax Info: contains extended AppleFax information which is used 
only when two AppleFax devices are communicating with each other. } 


AF IRec = ARRAY (0..iAFISize-1] OF uchar; { the bytes } 


{Record for xmit/receive line/packet command} 


FLineRec = RECORD 
Length: INTEGER; { number of bytes in the line } 
Data: BufPtr; { the bytes } 
END; 


pFLineRec = “FLineRec; 


(Standard Result Data} 
TFGenResult = PACKED RECORD | 
Result: SIGNEDBYTE; {result of call}: 
END; 


{*---- Fax modem command record structures see ese semen nn nnn nn nn ne } 
{The following structures are used with the firmware command calls to 
the fax modem} 


{ =a Status BR SRR SRS aS TS RASA SATA SSAA Tas SUS s } 
(Command Data} 
{NIL} 


{Return Data} 
TEIStatus = RECORD 


Result: SIGNEDBYTE; {status info} 
Command: SIGNEDBYTE; {currently executing command} 
ExtStatus: SIGNEDBYTE; {extended status} 

END; 


pTFIStatus = “TFIStatus; 


(Result Data} 
{NIL) 


{== FaxDial SATE 24822242832 2222 2Us= } 


(Command Data} 
TFOFaxDial = PACKED RECORD 


PhoneNum: PNumStr; {phone number to dial} 

IDNum: IDNumSt r; {station ID string} 

Capabilities: SFIRec; {capabilities} 

Mode: SIGNEDBYTE; {type of connection required} 

Fill SIGNEDBYTE; {filler} 

AppleFaxInfo: AFIRec; {apple fax specified information} 
END; 


pTFOFaxDial = “TFOFaxDial; 


(Return Data} 
{NIL} 


{Result Data} 
TFRFaxDial = PACKED RECORD 
Result: SIGNEDBYTE; {result of cail} 
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fiii0% SIGNEDBYTE; 
lONum: TONumStr;: 
ResultCap: SFIRec; 
Mode: SIGNEDBYTE:; 
S2ia SIGNEDBYTE; 


AppleFaxInfo: AFIRec; 
END; 
PTFRFaxDial = *TFRFaxDial; 
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(filler) 
{station ID string} 
{result capabilities} 
{type of connection required} 
{more filler} 
{apple fax specified information} 


izz raxAnswer SS SS SS25 2252S SaaS ae eeeeee eases eeseseseneeesss } 


{Command Data} 


TFOFaxAnswer = PACKED RECORD 


IDNum: TONumStr; 
Capabilities: SFIRec:; 
Mode: SIGNEDBYTE; 
bol i ip SIGNEDBYTE: 


AppleFaxInfo: AFIRec; 
END; 


pTFOFaxAnswer = *TFOFaxAnswer; 


{Return Data} 
{NIL} 


{Result Data} 
TFRFaxAnswer = TFRFaxDial;: 


pPTFRFaxAnswer = “TFRFaxAnswer; 


{Station ID string} 
{Capabilities} 
{type of connection required} 
(filler) 
{apple fax specified information} 


{same as FaxDial}y 


a 


{ m= FaxTransmit SSSR RSA e See aaa Sees eee essere } 


{Command Data} 
{NIL} 


{Return Data} 
{NIL} 


{Result Data} 
TFRFaxXmit = TFGenResult; 
PTFRFaxXmit = “TFRFaxXmit; 


{result of call} 


{== TransmitLine ne. NaS 2S 22S SLES SoA Lecsaesesssecosesceoes } 


(Command Data} 
TFOXmitLine = FLineRee;: 
pTFOXmitLine = “TFOXmitLine; 


{Return Data} 
{NIL} 


{Result Data) 
TFRXmitLine = TFGenResult; 
PTFRXmitLine = “TFRXmitLine;: 


{result of call) 


{## TransmitEnd eee) SSeS SSL oS Sooo Cease eens see } 


{Command Data} 
TFOXmitEnd = PACKED RECORD 
LastPage: BOOLEAN; 
END; 
pTFOXmitEnd = “TFOXmitEnd:; 


{Return Data} 
{NIL} 


{Result Data} 
TFRXmitEnd = PACKED RECORD 


Result: S IGNEDBYTE; 
Quality: SIGNEDBYTE; 
END; 


PTFRXmitEnd = “TPRXmitEnd; 


{TRUE is last page} 


{result of the call} 
(0 if image was unacceptable} 
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oo {Command Data) 
( (NIL 


‘Return Data} 
{NIL} 


a> te 


(Result Data} 
TFREFaxReve = TFGenResult; {result of call} 
pTFRFaxRecve “TERFaxRecve; 


ii 


{== ReceiveBu ffeyr ssazsee see see SSA SRSA SSSA ABS STS TASS AAzATTzAzss } 


(Command Data} 
TFORcveBfr = PACKED RECORD 
BufSize: INTEGER; {number of bytes to receive} 
END; 
pTFORcveBfr = “TFORcveBfr; 


(Return Data} 
TFIRcveBfr = PACKED RECORD 


Result: SIGNEDBYTE; {result of the call} 

Done: SIGNEDBYTE; {1 if last data of the current image} 

Length: INTEGER; {length of the buffer} 

Data: BufPtr; (pointer to buffer to receive data} 
END; : 


e 


pTFIRcveBfr = “TFIRcveBfr; 


(Result Data} 
TFRReveBfr = PACKED RECORD 


Result: SIGNEDBYTE; {result of the call} 
Done: SIGNEDBYTE; (1 if last data of the current image} 
END; 


pTFRReveBfr = “TFRReveBfr; 


{== Rece iveEnd s2s2aseseerr ss 2 sS S22 RES SAS BASES SASSI TISASSS AS Sass } 
{Command Data} 
TFORcveEnd = PACKED RECORD 
Quality: SIGNEDBYTE; {l if received image was acceptable) 
END; 
pTFORcveEnd = “TFORcveEnd; 


{Return Data} 
{NIL} 


(Result Data} 
TFRReveEnd = TFGenResult; {result of call} 
pTFRReveEnd = “TFRRcveEnd; 


(== TransmitPacket angen esene see ee ee ee 28 ee ee eee ese | 
(Command Data} 

TFOXmitPkt = FLineRec; 

pTFOXmitPkt = *TFOXmitPkt; 


{Return Data} 
(NIL} 


(Result Data} 


TFRXmitPkt = TFGenResult; {result of call} 
pTFRXmitPkt = *TFRXmitPkt; 
{ == ReceivePacket momusee sess es eres sees sees esses Ses sss Ss sss2e25=== } 


{Command Data} 
{NIL} 
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(Return Data} 
TFIRcvePkt = PACKED RECORD 


Result: SIGNEDBYTE; {result of the call} 

Cole SIGNEDBYTE; {fi11} 

Length: INTEGER; {length of the buffer} 

Data: BufPtr; {pointer to buffer to receive data} 
END; 


pTFiRevePkt = “TFIRcvePkt; 


{Resuls Data) 
TERRevePkt = TEGenResult; {result of call} 
pTFRRevePkt = *TFRRevePkt; 


(ee DL SCONNE CK SBS e eee s ees SSS SES SSS SSASSSSS SASS SASS SSSA SSS sss sss cS 8s } 


{Command Data} 
{NIL} 


{Return Data} 
(NIL) 


{Result Data} 
TFRDisconnect = TFGenResult; {result of call} 
pPTFRDisconnect = “TERDisconnect; 


” 


{mm GetRegister RABBI SOARS SSS SVN SB SSS Ts SS ss VAs SHAAN TASS 


{Command Data} 
TFOGetReg = PACKED RECORD 
Register: SIGNEDBYTE; {register number} 
END; 
pTFOGetReg = “TFOGetReg; 


a 


{Return Data} 
TFiGetReg = PACKED RECORD 


Result: SIGNEDBYTE; {result of the call} 

py a SIGNEDBYTE; {filler} 

Value: INTEGER; {value in the register} 
END; 


pTFiGetReg = “TFIGetReg; 


{Result Data} 
TFPRGetReg = PACKED RECORD 


Result: SIGNEDBYTE; {result of the call} 

ppp he ape SIGNEDBYTE; {filler} 

Value: INTEGER; {value in the register} 
END; 


pTFRGetReg = “TERGetReg; 


{== SetRegi SCOLC Ses eeeS Ses Ae SSS SV NSSSSSSSSSVSSKL SSB ASLSLSSOUSSeIsSesses2ses6 ) 


{Command Data} 
TFOSetReg = PACKED RECORD 


Register: SIGNEDBYTE; {register number} 

fill: SIGNEDBYTE; {filler} 

Value: INTEGER; {value in the register} 
END; 


pTFOSetReg = “TFOSetReg; 


{Return Data} 
TFISetReg = TFGenResult; 
- pTFISetReg = “TFISetReg; 


{Result Data} 
TFRSetReg = TFGenResult; 
pTFRSetReg = “TFRSetReg; 


{ss Reset ee ee EEE SESS SNES ASS SAS SSS SAAT SSE Ees ) 


{Command Data} 


eee 
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(NIL) 


(Return Data} 
{NIL} 


(Result Data} 
(NIL) 


i == Cancel SSL SS LSAT SSS SKS LKR AS RT SAA VSR STS RVG ATV TSS ses TSS ss TV Bsr sssz==== } 
(Command Data} 
(NIL} 


(Return Data} 
(NIL) 


{Result Data} 


{NIL} 
{Command Data} 
{NIL} 


(Return Data) 
TFIVersion = RECORD 


Result: SIGNEDBYTE; {status info} 

Pils SIGNEDBYTE; 

Version: INTEGER; {currently executing command} 
END; 


pTFIVersion = *TFIVersion;: 


(Result Data} 
TERVersion = RECORD 


Result: SIGNEDBYTE; {status info} 

Piid: SIGNEDBYTE; 

Version: INTEGER; {currently executing command) 
END; 


pIFRVersion = “TFRVersion; 


{== GetResult FS SS ISS SSR SVS SSS SSNS AAR SAAS SSSA ASATA ees AzTTs= === } 
{Command Data} 
{NIL} 


(Return Data} 
TFIResult = TFGenResult; {result of call} 
pTFIiResult = “TFIResult; 


‘Resuit Data} 
{NIL} 


( a= Pp ickUp Se AE SE AE A SA a 2 2 2 2S } 
{Command Data} 
(NIL} 


{Return Data} 
{NIL} 


(Result Data} 
TFRPickUp TFGenResult; {result of call} 
PTFRPickUp = “TFRPickUp; 


i] 


{Command Data} 
{NIL} 
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(Return Data) 
(NIL } 


‘Result Data} 
TFRHankUp = TFGenResult; {result of ¢ail} 
PTFRHankUp = “TFRHankUp; 


(emene Fax command record «-“<“cnceweeccana SS Pee wsesenamrasawoasnuwoowssaae ) 


{structure for passing fax commands to the low level driver} 
TFaxCmdRec = RECORD 


FaxCommand: INTEGER; {fax command to execute} 

hPacket: hFaxPacket; {packet handle to use} 

pPort: pSerialPair; {serial in / out reference info} 

pOutput: Ptr; {pointer to output structure} 

pInput: Ptr; {pointer to input structure} 

IdleProe: ProcPtr; {pointer to the user's idle procedure} 
END; 


oTFaxCmdRec = *TFaxCmdRec; 


{swore Fax options structures -eecses<--<- eenwwooorarecre owe mem were nese wroe } 
TExSaveFile = RECORD 
sFname: Ser255; 
sVRefNum: INTEGER; ‘ % 
sVersion: INTEGER; > 
END; = 
PTFxSaveFile = “TFxSaveFile; 
TFxSaveAddrFile = RECORD 
sFname:; Str255; oo 
sVRefNum: INTEGER; ( 
sWDDirID: LONGINT; 
sVersion: INTEGER; 


END; 
ptixFileChain = “TFxFileChain; 


TrxFiteChain = RECORD 


CELInAK: pTFxFileChain; 
eFname: Str255; 
eVRe fNum: INTEGER; 
eDirIbD: LONGINT; 

END; 


stri = STRING(1]; 
TOptsRec = RECORD 


Retries: INTEGER; {retries} 

ManualDial: BOOLEAN; {Manual dial} 

ModeFls: Stril: {(t)one or (p)ulse string} 
DialNumStr: PNumStr; {phone number string} 

IDNum: IONumSt cr; {calling telephone number string) 
StationID: TIDStr? {text ID message imaged at page top} 
DeSID: BOOLEAN; {poolean to image station id} 
StationName: PNumStr; {name of the applefax device} 


SaveFileRec: TFxSaveFile; 

AddrBookRec: TFxSaveAddrFile; 

pFileChain: pTiFxFileChain; {NIL if no files} 
END; 
TPOpts = “TOptsRec; 
THOpts = “TPOpts; 


(2e=e= General IO block structure cWs--eeennennn- a a a ath ec ec } 
TOParamBlockRec = RECORD 
{12 byte header used by the file and IO system} 
qLink: QElemPtr; {queue link in header} 
qType: INTEGER; {type byte for safety check) 
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ioTrap: INTEGER; (Fs: the Trap} 
loCmdAddr: Per; {FS: address to dispatch to} 


{common header to all variants} 
LoCompletion: ProcPtr; {completion routine addr (0 for 
synch calls) } 
LoResult: OSErr; {result code} 
ioNamePtr: StringPtr; (ptr to Vol:FileName string} 
ioVRefNum: INTEGER; {volume refnum (DrvNum for Eject and 
MountVol) } 


ioRefNum: INTEGER: {refNum for I/0 Operation} 
LoVersNum: SignedByte; (version number } 
LoPermssn: SignedByte; {Open: permissions (byte) } 


ioMise: Ptr; {Rename: new name } 

{(GetEOF, SerEForF: logical end of file} 

{Open: optional ptr to buffer} 

(SetFileType: new type} 

ioBuffer: Ptr; (data buffer Ptr} 

ioReqCount: LONGINT: (requested byte count; also = 
ioNewDirID} 

LoActCount: LONGINT; (actual byte count completed} 
loPosMode: INTEGER; {initial file Positioning) 
ioPosOffser: LONGINT; (file Position offset} 


(----- Assembly globals DOP a SE NGS. Gee Sorte seianesrpeane ase eck } 


(This following records are used by the low leve] assembly code. They are 
dynamically allocated instead of declared in the asm code as variable space. 
This is because the new machines with mem management units will not allow 
one to write into code space. PAC / 07-APR-87} 


{variables used for fax packet xmission} 
TExPack = RECORD 
{Position equates for PaxCmdOut variables} 


VSCCIO: IOParamBlockRec; {general I0 Param block} 

{VSCCIO: ARRAY [0..24] of INTEGER; } {general IO param dlock} 
VidlePtr:;: ProcPtr; {pointer to the idle procedure} 
VPktPtr: PFaxPacket; {pointer to fax Packet to use for xmit } 
VPortPair: pSerialPair; {ptr to the serial port info to use} 
VPLOffset; INTEGER; {ptr list offset to mext bfr to xmit} 
VIOPhase: INTEGER; {current state in the protocol} 

VRet ries; INTEGER; {number of retries to perform} 

VLength: INTEGER; {Ptr to receive Cotal len of the data} 
VTimeOut : LONGINT; {Number of ticks timeout allowed} | 


{Pointer list equates} 
VOutPtrs: Ptr: (pointer to output ptr list} 


VinPtrs: Ptr; {pointer to input ptr list} 
VNumOuts: INTEGER; {number of output elements in the list} 
VNumins:; INTEGER; {number of input elements in the list} 
{control response buffer} 
VCRBuf: INTEGER; {packet responce buffer} 

END; 


PTFxPack = “TFxPack; 


(*TMTask = RECORD 


qLink: PTR; 

qType: INTEGER; 

tmAddr: ProcPtr; 

CmCount: LONGINT; 
"END; *) 


7 (variables used for fax line xmission} 
( TFxDump = RECORD 
, (Routine parameters Or InitFaxDump} 
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(VPLandBMap: TPBitMap; } 
VPNumBfrs: LONGINT; 
VPSfrSize: LONGINT; 
VPLineList: PTR; 
VPCapable: pSFIiRec; 
VPSCCPair: pSerialPair; 


{variables used by FaxDumpBand)} 


(Flags, etc.} 
VXP rimea: INTEGER; 
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{landscape bitmap struct} 
{number of line bfrs} 
{size of the line bfrs} 


{pte 
{ptr 
{ptr 


ae) 


to list of line bfrs) 
capabilities structure} 


serial paiz} 


{timer routine Ras been primed) 


‘IO and band queue management pointers} 


VXP BBase: PTR; 
VXIOQBase: PTR; 
VXIO@Ptr: PTR; 
VXBdaOPtr: PTR; 


{Interupt task entry) 
VXTimeTask: TMTask; 
VXTimeFix: LONGINT; 

ENO; 

pTExDump = “TExDump; 


{ptr 
{pte 
{ptr 
(ptr 


to 
to 
ri) 
to 


the top of the PBs} 
cop of IO queue) 

lst queue element} 
top of band queue} 


{time manager task record} 
{time mgr kills this for some reason) 


(variables used by the low level driver} 


TFxDrver = RECORD 


fPrVars: TPPrVars; 
EAP rine: THPrint; 
fPrPort: TPPrPort; 
iVPos: INTEGER; 
BusyDlsg: DialogPtr; 


HOptions: THOpts; 
OurkxDev: BOOLEAN; 
OurHPrint: BOOLEAN; 
DeIt: BOOLEAN; 
END; 

eTFxDrvr = “TExDrvr; 


{All cf the fax vars are pointed to by this chunk) 


TFxDev # RECORD 
FxPackVars: TExPack; 
FxDumpVars: TE xDump; 
pFxDrvrVars: pTFxDrvr; 

END; 

pTFxDev = “TFxDev; 


{ The PicFile State Object } 
TPfState = RECORD 
RPies PicHandle: 
iDocPage: Integer; 
hFileName: Handle: 
PfHeader: TP fHeader; 


iPfRefNum: Integer; 
lPicBytes: LongInt; 


{fax packet variables} 
{fax line dump variables} 
{low level drvr variabies)} 


{The current Pic) 

{The current (DOC, not PrFile!) page. } 
{Default file name resource handle} 
{The PicFile's header) 


{The PicfFile's refnum} 
{The current pic's size. Zeroed in PfOpenPage, 
PfOut, used in PfClosePage to set directory entry for next page. } 


iBuf: Integer; {IO Buffer) 

bBuft: ARRAY(1..iFxIOBlkBytes] OF SignedByte; 
rDirty: rect; {DC 10/16/84} 
nPicSave: QDHandle; {DC 10/16/84) 
appClip, 

QDClip: rgnHandle; {DC 11/12/84} 
rFrame: rect; (DC 1/7/85} 


{PAC / 08-JUL-87)} 
HOptions: THOpts; 


incremented ina 
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StatDlg: DialogPtr; 
SaveGhost: DialogPtr; 
DoErrDlgs: BOOLEAN; 


DoStatusDlgs: BOOLEAN; 
fTheyAllocated: BOOLEAN; 
END; 
TPPfState = “TPfState; 
THPfState = “TPPfState; 


HD :MPW:Faxing:FxCode:FaxIntf£.P Page 


(temp ptr to the status dialog} 

(‘variable to save the ghost} 

{do the error dialogs} 

{do the status messages} 

{this structure was allocated externally} 


(The fax's use of the PrVars} 


TExVars = RECORD 


iPrErr: Integer; 
bDocLoop: SignedByte; 
bUserl: SignedByte; 
hPfState: THP fState; 
pFrxDev: pTFxDev; 
user2: TLONG; 

END; 


TPExVars = “TExVars; 


IMPLEMENTATION 


END. 


(Current print error. Set to iPrAbort to abort printing.} 
{The Doc style: Draft, Spool, .., and ..} 
(Currently use low 3 bits; the upper 5 are for flags. 
Bit 2 is fNewRun.} 
{Spares used by the print code} 
{1lUserl: The State handle. } 
(pointer to our fax packet variables} 


e , 


Appendix C 


Sample Procedures for Receiving a Fax File 


To receive fax files, your application must first detect the phone ringing and then determine 
if the caller is a fax machine by inspecting the capabilities returned by the FaxAnswer cail. 
If it is a fax machine, you can call the first procedure below to set up the files for reception. 
The next procedure actually receives the data, writing out the temp file in the correct packet 
format. In your own implementation ydu should be checking for errors and responding 
accordingly. 


Procedure: RecvFaxFile (theStationID, theCapabilities); 


VAR 
aTempFile: TFxSaveFile; 
aFinalFile: TFrxSaveFile; 
BEGIN 


{make the temp file and open it} 
anError := Create('TheRecvFile', tempVRefNum, 'YNOT’, 'TEMP’) ; 
anError := FSOpen('TheRecvFile', tempVRefNum, itsRefNum) ; 


{get the data} 
recvError := RecvFaxFileData(theStationID, theCapabilities, 
' itsRefNum) ; | 


{close the file} 
FSClose (itsRefNum) ; 


{make the final fax file} 
{Note: the creator and file type for the file} 
anError := Create('TheFaxFile', faxVRefNum, 'FFAX', 'FFIL'); 


{make the conversion} 

{set up the file records} 
aTempFile.sFname := 'TheRecvFile'; 
aTempFile.sVRefNum := tempVRefNum; 
aTempFile.sVersion := 0; 


aFinalFile.sFname 'TheFaxFile'; 
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END; 


aFinalFile.sVRefNum := faxVRefNum; ( 
aFinalFile.sVersion := 0; 


{do the conversion} 
anError := FxConvertFile (pTFxSaveFile (@aTempFile), 
pTFxSaveFile (@aFinalFile) ); 


{trash the temp File} 
anError := FSDelete('TheRecvFrile', tempVRefNum) ; 


FUNCTION: TFaxModem.RecvFaxFileData(theStationID: IDNumStr, theCapabilities: 
SFIRec; tempFile: INTEGER): OSEnr, 


CONST 
kCapabilities = 0; 
kStationID = 3 
kPageStart a, = 2; 
kPageData : = 3; : ; 
kLastPage = 4; = 
TYPE 
aPacket = RECORD 
theType: INTEGER; 
theLength: INTEGER; 
END; 
VAR 
thePacket: aPacket; 
numBytes: INTEGER; 
numTowrite: LONGINT; 
numToAdd: INTEGER; 
anError: | INTEGER; 
outRec: | TFORcveBfr; 
inRec: TFIRcveBfr; 
morePages: INTEGER; 
fileBuffer: TFileBuffer; 
BEGIN 


{set up ptr for data} 
inRec.Data := @MyBuffer; 


{write out capabilities} 
thePacket.theType >= kCapabilities; 
thePacket.theLength := SIZEOF(SFIRec) ; 
numToWrite := SIZEOF (aPacket) ; 


anError := FSWrite(tempFile, numToWrite, @thePacket) ; 
numToWrite := SIZEOF (SFIRec) ; 
anError := FSWrite(tempFile, numToWrite, @theCapabilities); 
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{write out station ID string} 


thePacket.theType >= kStationID; 
thePacket.theLength := LENGTH (theStationID) ; 

nhumToWrite := SIZEOF(aPacket) ; 

anError := FSWrite(tempFile, numToWrite, @thePacket) ; 
numToWrite := LENGTH (theStationID) ; 

anError >= FSWrite(tempFile, numToWrite, @theStationID); 


{set up modem to begin receiving the pages} 
WHILE (FaxReceive = 0) DO 

BEGIN 

inRec.Done := 0; 


{get the data} 
thePacket.theType := kPageStart; 


{Capture all the data for a page} 
REPEAT {UNTIL inRec.Done = 1} 

BEGIN 

anError := ReceiveBuffer (1024, inRec) ; 
{write data out to file} 
thePacket.theLength := inRec. Length; 
numToAdd ' 3 SIZEOF (aPacket) ; 
numToWrite >= SIZEOF (aPacket) ; 

IF thePacket.theLength > 0 THEN 
anError := FSWrite(tempFile, numToWrite, @thePacket) ; 
numToAdd := inRec.Length; 

numToWrite := inRec.Length; 

IF thePacket.theLength > 0 THEN 

anError := FSWrite(tempFile, humToWrite, inRec.Data); 
thePacket.theType := kPageData; 

END 


UNTIL inRec.Done = 1; 
anError:= ReceiveEnd(1); {always returnl for quality OK} 
If anError <> noErr THEN {no more pages to receive} 


BEGIN 

{put out end of page stuff} 

thePacket .theType >= kLastPage; 

thePacket.theLength := 0; 

numToWrite >= SIZEOF (aPacket) ; 

anError := FSWrite(tempFile, numToWrite, @thePacket) ; 
RecvFaxFileData >= anError; 

EXIT (RecvFaxFileData) ; 

END; 

{set up for next page} 

thePacket .theType >= kPageStart; 

thePacket.theLength := 0; 

numToWrite >= SIZEOF (aPacket) ; 

anError >= FSWrite(tempFile, numToWrite, Q@thePacket) ; 


END; {WHILE (FaxReceive = QO) } 


Ps 
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END; 


{write out the end of file packet} 
thePacket .theType := kLastPage; 


thePacket .theLength QO; 
numTowWrite SIZEOF (aPacket) ; 


anError := FSWrite(tempFile, numToWrite, @thePacket); 


{return any errors} 
RecvFaxFileData := anError; 


AppleFax Modem Preliminary Notes 9/29/87 


